{"version":3,"sources":["webpack:///./node_modules/incremental-convex-hull/ich.js","webpack:///./node_modules/@turf/invariant/index.js","webpack:///./node_modules/@turf/flatten/index.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/meta/index.js","webpack:///./node_modules/@turf/point-on-surface/index.js","webpack:///./node_modules/@turf/bezier/index.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/meta/index.js","webpack:///./node_modules/polygonize/dist/Graph.js","webpack:///./node_modules/geojson-equality/index.js","webpack:///./node_modules/geodesy/osgridref.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCurrentFieldBorderLayer.vue?0f46","webpack:///wwwroot/src/vue/areas/field-record-system/components/base/FrsCurrentFieldBorderLayer.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCurrentFieldBorderLayer.vue?583e","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCurrentFieldBorderLayer.vue","webpack:///./node_modules/robust-scale/robust-scale.js","webpack:///./node_modules/@turf/square/index.js","webpack:///./node_modules/geodesy/mgrs.js","webpack:///./node_modules/@turf/random/index.js","webpack:///./node_modules/@turf/isolines/node_modules/marchingsquares/marchingsquares-isocontours.js","webpack:///./node_modules/polygonize/dist/Node.js","webpack:///./node_modules/ms/index.js","webpack:///./node_modules/@turf/flip/index.js","webpack:///./node_modules/@turf/buffer/index.js","webpack:///./node_modules/@turf/planepoint/index.js","webpack:///./node_modules/convex-hull/ch.js","webpack:///./node_modules/@turf/tin/index.js","webpack:///./node_modules/@turf/transform-scale/index.js","webpack:///./node_modules/convex-hull/lib/ch1d.js","webpack:///./node_modules/geojson-dissolve/node_modules/@turf/meta/index.js","webpack:///./node_modules/grid-to-matrix/node_modules/@turf/helpers/main.es.js","webpack:///./node_modules/grid-to-matrix/node_modules/@turf/invariant/main.es.js","webpack:///./node_modules/grid-to-matrix/node_modules/@turf/meta/main.es.js","webpack:///./node_modules/grid-to-matrix/index.js","webpack:///./wwwroot/src/vue/components/InputClearButton.vue?1452","webpack:///wwwroot/src/vue/components/InputClearButton.vue","webpack:///./wwwroot/src/vue/components/InputClearButton.vue?b9e6","webpack:///./wwwroot/src/vue/components/InputClearButton.vue","webpack:///./node_modules/simplicial-complex/topology.js","webpack:///./node_modules/geojson-random/index.js","webpack:///./node_modules/@turf/rhumb-destination/index.js","webpack:///./node_modules/lineclip/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsModuleRoot.vue?8fea","webpack:///./node_modules/geodesy/latlon-vincenty.js","webpack:///./node_modules/@turf/boolean-disjoint/index.js","webpack:///./wwwroot/src/vue/components/geometry/RedBorderPreview.vue?0442","webpack:///./node_modules/@turf/projection/index.js","webpack:///./node_modules/deep-equal/lib/keys.js","webpack:///./node_modules/@turf/circle/index.js","webpack:///./wwwroot/src/vue/components/card/ListCard.vue?fa5b","webpack:///./node_modules/debug/src/browser.js","webpack:///./node_modules/@turf/explode/index.js","webpack:///./node_modules/topojson-server/src/bounds.js","webpack:///./node_modules/topojson-server/src/hash/hashset.js","webpack:///./node_modules/topojson-server/src/hash/hashmap.js","webpack:///./node_modules/topojson-server/src/hash/point-equal.js","webpack:///./node_modules/topojson-server/src/hash/point-hash.js","webpack:///./node_modules/topojson-server/src/join.js","webpack:///./node_modules/topojson-server/src/cut.js","webpack:///./node_modules/topojson-server/src/dedup.js","webpack:///./node_modules/topojson-server/src/delta.js","webpack:///./node_modules/topojson-server/src/extract.js","webpack:///./node_modules/topojson-server/src/geometry.js","webpack:///./node_modules/topojson-server/src/prequantize.js","webpack:///./node_modules/topojson-server/src/topology.js","webpack:///./node_modules/topojson-server/index.js","webpack:///./node_modules/@turf/boolean-overlap/index.js","webpack:///./node_modules/@turf/area/index.js","webpack:///./node_modules/@turf/within/index.js","webpack:///./node_modules/@turf/line-chunk/index.js","webpack:///./node_modules/geojson-utils/geojson-utils.js","webpack:///./wwwroot/src/vue/components/bootstrap/BsCheckbox.vue?c558","webpack:///wwwroot/src/vue/components/bootstrap/BsCheckbox.vue","webpack:///./wwwroot/src/vue/components/bootstrap/BsCheckbox.vue?3c21","webpack:///./wwwroot/src/vue/components/bootstrap/BsCheckbox.vue","webpack:///./node_modules/simplepolygon/node_modules/@turf/meta/index.js","webpack:///./node_modules/@turf/rewind/index.js","webpack:///./node_modules/marchingsquares/dist/marchingsquares-esm.js","webpack:///./node_modules/@turf/bbox/index.js","webpack:///./node_modules/@turf/union/index.js","webpack:///./node_modules/@turf/rhumb-distance/index.js","webpack:///./wwwroot/src/vue/components/geometry/RedBorderPreview.vue?e7f2","webpack:///wwwroot/src/vue/components/geometry/RedBorderPreview.vue","webpack:///./wwwroot/src/vue/components/geometry/RedBorderPreview.vue?21fd","webpack:///./wwwroot/src/vue/components/geometry/RedBorderPreview.vue","webpack:///./node_modules/polygonize/dist/EdgeRing.js","webpack:///./wwwroot/src/vue/components/bootstrap/BsCheckbox.vue?2c87","webpack:///./node_modules/@turf/center/index.js","webpack:///./node_modules/@turf/concave/index.js","webpack:///./node_modules/@turf/idw/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapsModuleRoot.vue?d56d","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapCreation.vue?18b1","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapCreation.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapCreation.vue?4bda","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapCreation.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatelliteImageSelection.vue?bc0f","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ChannelSelector.vue?946a","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/ChannelSelector.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ChannelSelector.vue?b942","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ChannelSelector.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/FilterSelector.vue?2d29","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/FilterSelector.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/FilterSelector.vue?6c04","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/FilterSelector.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageLayer.vue?8192","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageLayer.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageLayer.vue?5fb0","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageLayer.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageCard.vue?a818","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageCard.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageCard.vue?d7f4","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageCard.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/LoadMoreButton.vue?ad76","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/LoadMoreButton.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/LoadMoreButton.vue?e8db","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/LoadMoreButton.vue","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatelliteImageSelection.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatelliteImageSelection.vue?3bf8","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatelliteImageSelection.vue","webpack:///wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapsModuleRoot.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapsModuleRoot.vue?3414","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapsModuleRoot.vue","webpack:///./node_modules/@turf/truncate/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ChannelSelector.vue?1ee9","webpack:///./node_modules/@turf/bbox-polygon/index.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/center/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/LoadMoreButton.vue?6296","webpack:///./node_modules/@turf/isolines/index.js","webpack:///./node_modules/simplify-js/simplify.js","webpack:///./node_modules/earcut/src/earcut.js","webpack:///./node_modules/geodesy/npm.js","webpack:///./wwwroot/src/vue/components/search/SearchBar.vue?76e3","webpack:///wwwroot/src/vue/components/search/SearchBar.vue","webpack:///./wwwroot/src/vue/components/search/SearchBar.vue?800e","webpack:///./wwwroot/src/vue/components/search/SearchBar.vue","webpack:///./node_modules/geojson-dissolve/index.js","webpack:///./node_modules/@turf/bbox-clip/index.js","webpack:///./node_modules/@turf/boolean-contains/index.js","webpack:///./wwwroot/src/vue/components/forms/NumericInput.vue?640c","webpack:///./node_modules/@turf/polygon-tangents/index.js","webpack:///./node_modules/@turf/destination/index.js","webpack:///./node_modules/@turf/unkink-polygon/index.js","webpack:///./node_modules/geodesy/latlon-ellipsoidal.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatelliteImageSelection.vue?4047","webpack:///./node_modules/wgs84/index.js","webpack:///./node_modules/@turf/combine/index.js","webpack:///./node_modules/geojson-rbush/index.js","webpack:///./node_modules/@turf/square-grid/index.js","webpack:///./node_modules/@turf/triangle-grid/index.js","webpack:///./node_modules/@turf/intersect/index.js","webpack:///./node_modules/@turf/meta/index.js","webpack:///./node_modules/@turf/midpoint/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/ZoneMapCreation.vue?5637","webpack:///./node_modules/@turf/polygon-to-linestring/index.js","webpack:///./node_modules/affine-hull/aff.js","webpack:///./wwwroot/src/vue/components/ToggleButton.vue?0d7f","webpack:///./node_modules/@turf/line-distance/index.js","webpack:///./node_modules/deep-equal/index.js","webpack:///./node_modules/@turf/line-slice/index.js","webpack:///wwwroot/src/vue/components/VueSelectize.vue","webpack:///./wwwroot/src/vue/components/map/IxWmsLayer.vue?8361","webpack:///./node_modules/@turf/dissolve/index.js","webpack:///./node_modules/@turf/inside/index.js","webpack:///./node_modules/@turf/envelope/index.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/inside/index.js","webpack:///./node_modules/@turf/line-slice-along/index.js","webpack:///./node_modules/@turf/centroid/index.js","webpack:///./node_modules/@turf/line-offset/intersection.js","webpack:///./node_modules/jsts/dist/jsts.min.js","webpack:///./node_modules/@turf/distance/index.js","webpack:///./node_modules/convex-hull/lib/ch2d.js","webpack:///./node_modules/@turf/nearest/index.js","webpack:///./node_modules/robust-orientation/orientation.js","webpack:///./wwwroot/src/vue/components/table/SimpleTable.vue?4534","webpack:///./wwwroot/src/vue/components/table/SimpleTableSortingButton.vue?1702","webpack:///wwwroot/src/vue/components/table/SimpleTableSortingButton.vue","webpack:///./wwwroot/src/vue/components/table/SimpleTableSortingButton.vue?11b7","webpack:///./wwwroot/src/vue/components/table/SimpleTableSortingButton.vue","webpack:///wwwroot/src/vue/components/table/SimpleTable.vue","webpack:///./wwwroot/src/vue/components/table/SimpleTable.vue?af40","webpack:///./wwwroot/src/vue/components/table/SimpleTable.vue","webpack:///./node_modules/geodesy/vector3d.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/helpers/index.js","webpack:///./node_modules/@turf/boolean-point-on-line/index.js","webpack:///./node_modules/debug/src/debug.js","webpack:///./node_modules/@turf/bezier/spline.js","webpack:///./wwwroot/src/vue/components/InputClearButton.vue?e664","webpack:///./node_modules/@turf/isobands/node_modules/@turf/area/index.js","webpack:///./node_modules/@turf/simplify/index.js","webpack:///./node_modules/deep-equal/lib/is_arguments.js","webpack:///./node_modules/@turf/point-to-line-distance/index.js","webpack:///./node_modules/@mapbox/geojson-area/index.js","webpack:///./node_modules/@turf/polygonize/index.js","webpack:///./node_modules/@turf/point-grid/index.js","webpack:///./node_modules/geodesy/utm.js","webpack:///./node_modules/@turf/convex/index.js","webpack:///./node_modules/d3-geo/src/adder.js","webpack:///./node_modules/d3-geo/src/math.js","webpack:///./node_modules/d3-geo/src/noop.js","webpack:///./node_modules/d3-geo/src/stream.js","webpack:///./node_modules/d3-geo/src/area.js","webpack:///./node_modules/d3-geo/src/cartesian.js","webpack:///./node_modules/d3-geo/src/bounds.js","webpack:///./node_modules/d3-geo/src/centroid.js","webpack:///./node_modules/d3-geo/src/constant.js","webpack:///./node_modules/d3-geo/src/compose.js","webpack:///./node_modules/d3-geo/src/rotation.js","webpack:///./node_modules/d3-geo/src/circle.js","webpack:///./node_modules/d3-geo/src/clip/buffer.js","webpack:///./node_modules/d3-geo/src/pointEqual.js","webpack:///./node_modules/d3-geo/src/clip/rejoin.js","webpack:///./node_modules/d3-geo/src/polygonContains.js","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/range.js","webpack:///./node_modules/d3-array/src/ticks.js","webpack:///./node_modules/d3-array/src/threshold/sturges.js","webpack:///./node_modules/d3-array/src/merge.js","webpack:///./node_modules/d3-array/src/zip.js","webpack:///./node_modules/d3-geo/src/clip/index.js","webpack:///./node_modules/d3-geo/src/clip/antimeridian.js","webpack:///./node_modules/d3-geo/src/clip/circle.js","webpack:///./node_modules/d3-geo/src/clip/line.js","webpack:///./node_modules/d3-geo/src/clip/rectangle.js","webpack:///./node_modules/d3-geo/src/clip/extent.js","webpack:///./node_modules/d3-geo/src/length.js","webpack:///./node_modules/d3-geo/src/distance.js","webpack:///./node_modules/d3-geo/src/contains.js","webpack:///./node_modules/d3-geo/src/graticule.js","webpack:///./node_modules/d3-geo/src/interpolate.js","webpack:///./node_modules/d3-geo/src/path/area.js","webpack:///./node_modules/d3-geo/src/identity.js","webpack:///./node_modules/d3-geo/src/path/bounds.js","webpack:///./node_modules/d3-geo/src/path/centroid.js","webpack:///./node_modules/d3-geo/src/path/context.js","webpack:///./node_modules/d3-geo/src/path/measure.js","webpack:///./node_modules/d3-geo/src/path/string.js","webpack:///./node_modules/d3-geo/src/path/index.js","webpack:///./node_modules/d3-geo/src/transform.js","webpack:///./node_modules/d3-geo/src/projection/fit.js","webpack:///./node_modules/d3-geo/src/projection/resample.js","webpack:///./node_modules/d3-geo/src/projection/index.js","webpack:///./node_modules/d3-geo/src/projection/conic.js","webpack:///./node_modules/d3-geo/src/projection/cylindricalEqualArea.js","webpack:///./node_modules/d3-geo/src/projection/conicEqualArea.js","webpack:///./node_modules/d3-geo/src/projection/albers.js","webpack:///./node_modules/d3-geo/src/projection/albersUsa.js","webpack:///./node_modules/d3-geo/src/projection/azimuthal.js","webpack:///./node_modules/d3-geo/src/projection/azimuthalEqualArea.js","webpack:///./node_modules/d3-geo/src/projection/azimuthalEquidistant.js","webpack:///./node_modules/d3-geo/src/projection/mercator.js","webpack:///./node_modules/d3-geo/src/projection/conicConformal.js","webpack:///./node_modules/d3-geo/src/projection/equirectangular.js","webpack:///./node_modules/d3-geo/src/projection/conicEquidistant.js","webpack:///./node_modules/d3-geo/src/projection/equalEarth.js","webpack:///./node_modules/d3-geo/src/projection/gnomonic.js","webpack:///./node_modules/d3-geo/src/projection/identity.js","webpack:///./node_modules/d3-geo/src/projection/naturalEarth1.js","webpack:///./node_modules/d3-geo/src/projection/orthographic.js","webpack:///./node_modules/d3-geo/src/projection/stereographic.js","webpack:///./node_modules/d3-geo/src/projection/transverseMercator.js","webpack:///./node_modules/d3-geo/src/index.js","webpack:///./node_modules/robust-sum/robust-sum.js","webpack:///./node_modules/bit-twiddle/twiddle.js","webpack:///./node_modules/@turf/kinks/index.js","webpack:///./node_modules/@turf/collect/index.js","webpack:///./node_modules/@turf/difference/index.js","webpack:///./node_modules/geojson-polygon-self-intersections/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/FilterSelector.vue?3ac5","webpack:///./node_modules/@turf/bearing/index.js","webpack:///./node_modules/@turf/mask/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/mixins/DisableDefaultMapInteractionsMixin.js","webpack:///./node_modules/geodesy/latlon-vectors.js","webpack:///./node_modules/geojson-flatten/index.js","webpack:///./node_modules/@turf/along/index.js","webpack:///./node_modules/@turf/sample/index.js","webpack:///./node_modules/@turf/isolines/node_modules/marchingsquares/marchingsquares-isobands.js","webpack:///./node_modules/@turf/tesselate/index.js","webpack:///./wwwroot/src/vue/components/ToggleButton.vue?b7cd","webpack:///wwwroot/src/vue/components/ToggleButton.vue","webpack:///./wwwroot/src/vue/components/ToggleButton.vue?41d5","webpack:///./wwwroot/src/vue/components/ToggleButton.vue","webpack:///./node_modules/@turf/line-intersect/index.js","webpack:///./wwwroot/src/vue/components/table/SimpleTableSortingButton.vue?f21b","webpack:///./node_modules/@turf/isobands/node_modules/@turf/invariant/index.js","webpack:///./node_modules/simplepolygon/node_modules/@turf/helpers/index.js","webpack:///./node_modules/@turf/boolean-clockwise/index.js","webpack:///./node_modules/@turf/great-circle/arc.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCultivationOverviewTable.vue?6c0e","webpack:///wwwroot/src/vue/areas/field-record-system/components/base/FrsCultivationOverviewTable.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCultivationOverviewTable.vue?36fb","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCultivationOverviewTable.vue","webpack:///./node_modules/@turf/buffer/node_modules/@turf/helpers/index.js","webpack:///./node_modules/@turf/line-arc/index.js","webpack:///./node_modules/@turf/tag/index.js","webpack:///./node_modules/two-product/two-product.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsCultivationOverviewTable.vue?13b6","webpack:///./node_modules/geodesy/dms.js","webpack:///./node_modules/geojson-linestring-dissolve/index.js","webpack:///./node_modules/simplepolygon/node_modules/@turf/area/index.js","webpack:///./node_modules/@turf/linestring-to-polygon/index.js","webpack:///./node_modules/polygonize/dist/index.js","webpack:///./node_modules/@turf/turf/module.js","webpack:///./node_modules/@turf/sector/index.js","webpack:///./wwwroot/src/vue/components/table/SimpleTable.vue?4702","webpack:///./node_modules/polygonize/dist/Edge.js","webpack:///./node_modules/@turf/isobands/index.js","webpack:///./node_modules/monotone-convex-hull-2d/index.js","webpack:///./node_modules/convex-hull/lib/chnd.js","webpack:///./node_modules/@turf/line-overlap/index.js","webpack:///./wwwroot/src/vue/components/VueSelectize.vue?478a","webpack:///./wwwroot/src/vue/components/VueSelectize.vue?3e3f","webpack:///./wwwroot/src/vue/components/VueSelectize.vue","webpack:///./wwwroot/src/vue/components/card/ListCard.vue?7fb1","webpack:///wwwroot/src/vue/components/card/ListCard.vue","webpack:///./wwwroot/src/vue/components/card/ListCard.vue?22af","webpack:///./wwwroot/src/vue/components/card/ListCard.vue","webpack:///./node_modules/two-sum/two-sum.js","webpack:///./node_modules/@turf/clean-coords/index.js","webpack:///./node_modules/geodesy/latlon-spherical.js","webpack:///./node_modules/@turf/rhumb-bearing/index.js","webpack:///./wwwroot/src/vue/components/map/IxWmsLayer.vue?ac72","webpack:///wwwroot/src/vue/components/map/IxWmsLayer.vue","webpack:///./wwwroot/src/vue/components/map/IxWmsLayer.vue?58b5","webpack:///./wwwroot/src/vue/components/map/IxWmsLayer.vue","webpack:///./node_modules/@turf/line-split/index.js","webpack:///./node_modules/polygonize/dist/util.js","webpack:///./wwwroot/src/vue/components/forms/NumericInput.vue?9da2","webpack:///wwwroot/src/vue/components/forms/NumericInput.vue","webpack:///./wwwroot/src/vue/components/forms/NumericInput.vue?e4fb","webpack:///./wwwroot/src/vue/components/forms/NumericInput.vue","webpack:///./node_modules/union-find/index.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/explode/index.js","webpack:///./node_modules/topojson-client/src/identity.js","webpack:///./node_modules/topojson-client/src/transform.js","webpack:///./node_modules/topojson-client/src/bbox.js","webpack:///./node_modules/topojson-client/src/reverse.js","webpack:///./node_modules/topojson-client/src/feature.js","webpack:///./node_modules/topojson-client/src/stitch.js","webpack:///./node_modules/topojson-client/src/mesh.js","webpack:///./node_modules/topojson-client/src/merge.js","webpack:///./node_modules/topojson-client/src/bisect.js","webpack:///./node_modules/topojson-client/src/neighbors.js","webpack:///./node_modules/topojson-client/src/untransform.js","webpack:///./node_modules/topojson-client/src/quantize.js","webpack:///./node_modules/topojson-client/index.js","webpack:///./node_modules/@turf/great-circle/index.js","webpack:///./node_modules/robust-subtract/robust-diff.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/center/node_modules/@turf/bbox/index.js","webpack:///./node_modules/@turf/boolean-equal/index.js","webpack:///./wwwroot/src/vue/components/search/Search.vue?376d","webpack:///wwwroot/src/vue/components/search/Search.vue","webpack:///./wwwroot/src/vue/components/search/Search.vue?6d1e","webpack:///./wwwroot/src/vue/components/search/Search.vue","webpack:///./node_modules/@turf/point-on-line/index.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/bbox/index.js","webpack:///./node_modules/@turf/boolean-within/index.js","webpack:///./node_modules/@turf/hex-grid/index.js","webpack:///./node_modules/@turf/transform-translate/index.js","webpack:///./node_modules/@turf/boolean-crosses/index.js","webpack:///./node_modules/get-closest/index.js","webpack:///./wwwroot/src/vue/components/table/SimpleTableBoolean.vue?b4b1","webpack:///wwwroot/src/vue/components/table/SimpleTableBoolean.vue","webpack:///./wwwroot/src/vue/components/table/SimpleTableBoolean.vue?b26f","webpack:///./wwwroot/src/vue/components/table/SimpleTableBoolean.vue","webpack:///./wwwroot/src/vue/components/table/SimpleTableStringArray.js","webpack:///./wwwroot/src/vue/components/table/SimpleTableAutoCell.js","webpack:///./node_modules/@turf/clone/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/zone-maps/SatImageCard.vue?8a56","webpack:///./node_modules/@turf/center-of-mass/index.js","webpack:///./node_modules/@turf/isolines/node_modules/grid-to-matrix/index.js","webpack:///./node_modules/@turf/line-segment/index.js","webpack:///./node_modules/@turf/isolines/node_modules/marchingsquares/marchingsquares.js","webpack:///./node_modules/simplepolygon/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsModuleRoot.vue?17c4","webpack:///wwwroot/src/vue/areas/field-record-system/components/base/FrsModuleRoot.vue","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsModuleRoot.vue?0b22","webpack:///./wwwroot/src/vue/areas/field-record-system/components/base/FrsModuleRoot.vue","webpack:///./node_modules/@turf/transform-rotate/index.js","webpack:///./node_modules/@turf/helpers/index.js","webpack:///./node_modules/@turf/line-offset/index.js","webpack:///./node_modules/fuse.js/dist/fuse.js"],"names":["module","exports","incrementalConvexHull","orient","__webpack_require__","compareCell","compareCells","Simplex","vertices","adjacent","boundary","this","lastVisited","GlueFacet","cell","index","compareGlue","a","b","bakeOrient","d","code","i","push","proc","Function","join","test","prototype","flip","t","u","BAKED","Triangulation","dimension","simplices","interior","filter","c","tuple","Array","o","proto","points","randomSearch","n","length","Error","initialSimplex","slice","apply","initialCoords","initialCell","list","verts","j","adj","v","k","indexOf","triangles","useRandom","insert","handleBoundaryDegeneracy","point","toVisit","pop","cellAdj","neighbor","nv","vv","walk","random","initIndex","Math","outerLoop","cellVerts","prev","addPeaks","tovisit","glueFacets","indexOfN","indexOfNeg1","na","vverts","vadj","ncell","opposite","uu","nface","nptr","sort","ai","bi","cells","nc","bcell","cv","ptr","parity","getCoord","obj","coordinates","getCoords","geometry","containsNumber","isArray","geojsonType","value","type","name","featureOf","feature","collectionOf","featureCollection","features","getGeom","geojson","undefined","geometries","getGeomType","geom","flattenEach","results","coordEach","layer","callback","excludeWrapCoord","g","l","stopG","coords","geometryMaybeCollection","isGeometryCollection","wrapShrink","currentIndex","isFeatureCollection","isFeature","stop","coordReduce","initialValue","previousValue","currentCoords","propEach","properties","propReduce","currentProperties","featureEach","featureReduce","currentFeature","coordAll","coord","geomEach","geomReduce","currentGeometry","centroid","distance","inside","explode","pointOnSurface","fc","cent","onSurface","x","y","x1","y1","x2","y2","onLine","onMultiPoint","pointOnSegment","line","f","closestVertex","concat","closestDistance","Infinity","dist","ab","sqrt","ap","pb","linestring","lineString","Spline","resolution","sharpness","spline","map","pt","duration","pos","floor","featureIndex","geometryIndex","coordIndex","featureSubIndex","geomType","currentCoord","geometryProperties","forEach","coordinate","flattenReduce","segmentEach","previousCoords","currentSegment","segmentReduce","currentSubIndex","lineEach","subIndex","multi","ring","lineReduce","currentLine","lineIndex","lineSubIndex","_createClass","defineProperties","target","props","descriptor","enumerable","configurable","writable","Object","defineProperty","key","Constructor","protoProps","staticProps","_classCallCheck","instance","TypeError","Node","Edge","EdgeRing","_require","_require2","validateGeoJson","geoJson","Graph","edges","nodes","id","buildId","node","from","to","edge","symetricEdge","getSymetric","graph","cur","start","getNode","end","addEdge","_this","keys","_removeIfDangle","_this2","innerEdges","outerNodes","getOuterEdges","e","removeNode","_this3","_computeNextCWEdges","_findLabeledEdgeRings","label","symetric","removeEdge","_this4","getOuterEdge","next","firstOutDE","prevInDE","de","sym","outDE","inDE","edgeRingStarts","isEqual","_this5","_findIntersectionNodes","_computeNextCCWEdges","edgeRingList","_findEdgeRing","startEdge","intersectionNodes","_loop","degree","edgeRing","_this6","deleteEdge","deepEqual","Equality","opt","precision","direction","pseudoNode","objectComparator","part","replace","sameLength","g1","g2","hasOwnProperty","obj1","obj2","strict","compare","compareCoord","compareLine","comparePolygon","compareFeature","context","g1s","g2s","every","g1part","some","g2part","c1","c2","toFixed","path1","path2","ind","isPoly","p1","removePseudo","p2","fixStartIndex","sameDirection","comparePath","reverse","sourcePath","targetPath","correctPath","cont","holes1","holes2","h1","h2","compareBBox","bbox","path","LatLon","OsGridRef","easting","northing","Number","latLonToOsGrid","datum","OSGB36","convertDatum","φ","lat","toRadians","λ","lon","F0","φ0","λ0","N0","E0","e2","n2","n3","cosφ","cos","sinφ","sin","ν","ρ","pow","η2","Ma","Mb","Mc","Md","M","cos3φ","cos5φ","tan2φ","tan","tan4φ","I","II","III","IIIA","IV","V","VI","Δλ","Δλ2","Δλ3","Δλ4","Δλ5","Δλ6","N","E","osGridToLatLon","gridref","WGS84","tanφ","tan6φ","secφ","ν3","ν5","ν7","VII","VIII","IX","X","XI","XII","XIIA","dE","dE2","dE3","dE4","dE5","dE6","dE7","toDegrees","parse","String","trim","match","l1","toUpperCase","charCodeAt","l2","e100km","n100km","en","split","toString","digits","isNaN","RangeError","eInt","eDec","nInt","nDec","ePad","nPad","e100k","n100k","letterPair","fromCharCode","render","_vm","_h","$createElement","_c","_self","attrs","vector-style","vectorStyle","z-index","staticRenderFns","FrsCurrentFieldBorderLayervue_type_script_lang_js_","components","IxVectorLayer","data","loading","computed","_objectSpread","vuex_esm","map_styles","methods","reloadGeometry","_reloadGeometry","asyncToGenerator","regeneratorRuntime","mark","_callee","url","response","wrap","_context","fieldId","harvestYear","abrupt","axios_default","get","sent","$store","dispatch","arguments","watch","immediate","handler","base_FrsCurrentFieldBorderLayervue_type_script_lang_js_","component","componentNormalizer","__webpack_exports__","twoProduct","twoSum","scaleLinearExpansion","scale","ts","q","count","pq","bv","west","south","east","north","horizontalDistance","verticalDistance","verticalMidpoint","horizontalMidpoint","Utm","Mgrs","zone","band","latBands","e100kLetters","n100kLetters","toMgrs","latlong","toLatLonE","charAt","col","row","toUtm","hemisphere","e100kNum","n100kNum","latBand","nBand","n2M","mgrsGridRef","gzd","en100k","eRounded","nRounded","options","polygon","num_vertices","max_radial_length","__WEBPACK_AMD_DEFINE_ARRAY__","__WEBPACK_AMD_DEFINE_RESULT__","root","factory","isoContours","defaultSettings","successCallback","verbose","settings","threshold","optionKeys","val","console","log","ret","ContourGrid2Paths","computeContourGrid","interpolateX","y0","rows","cols","ContourGrid","cval","tl","tr","br","bl","top","bottom","left","right","flipped","average","isSaddle","isTrivial","clearCell","getXY","grid","paths","path_idx","epsilon","gg","p","tracePath","merged","info","abs","unshift","dx","dy","maxj","dxContour","dyContour","nextEdge","currentCell","prev_cval","orientationIndex","outerEdges","outerEdgesSorted","aNode","bNode","det","d1","d2","sortOuterEdges","s","m","h","str","exec","parseFloat","toLowerCase","fmtShort","ms","round","fmtLong","plural","ceil","long","JSON","stringify","mutate","d3","jsts","meta","center","helpers","turfBbox","projection","toWgs84","toMercator","radiansToDistance","distanceToRadians","buffer","radius","units","steps","projected","buffered","needsTransverseMercator","defineProjection","projectCoords","result","reader","io","GeoJSONReader","read","writer","GeoJSONWriter","write","coordsIsNaN","unprojectCoords","invert","rotate","geoTransverseMercator","multiBuffered","invariant","triangle","outer","z1","z2","x3","y3","z3","z","convexHull1d","convexHull2d","convexHullnd","convexHull","featurecollection","Triangle","A","B","C","D","F","G","r","byX","dedup","splice","triangulate","xmin","xmax","ymin","ymax","dmax","xmid","ymid","open","__sentinel","closed","isPointZ","clone","turfBBox","rhumbBearing","rhumbDistance","rhumbDestination","factor","origin","isPoint","defineOrigin","originalDistance","bearing","newDistance","newCoord","originIsPoint","lo","hi","isObject","input","constructor","gridToMatrix","zProperty","flags","pointsMatrix","sortPointsByLatLng","matrix","pointRow","matrixPosition","pointsByLatitude","orderedRowsByLatitude","rowOrderedByLongitude","pointMatrix","directives","rawName","expression","staticClass","style","tabindex","role","aria-label","on","click","$event","stopPropagation","$emit","InputClearButtonvue_type_script_lang_js_","show","Boolean","components_InputClearButtonvue_type_script_lang_js_","bits","UnionFind","max","il","countVertices","vc","jl","cloneCells","ncells","min","m1","l0","m0","as","bs","compareZipped","normalize","attr","len","zipped","unique","findCell","mid","incidence","from_cells","to_cells","cl","kn","popCount","idx","dual","vertex_count","skeleton","res","k0","nextCombination","connectedComponents_dense","labels","link","component_labels","ranks","find","connectedComponents_sparse","vj","connectedComponents","position","coordInBBBOX","vertexToCoordinate","hub","rnd","collection","circle_offsets","sumOffsets","scaleOffsets","arr","PI","radial_scaler","GeodesyLatLon","LatLonSpherical","distanceInMeters","destination","rhumbDestinationPoint","lineclip","codeB","lastCode","codeA","bitCode","intersect","polygonclip","prevInside","polyline","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FrsModuleRoot_vue_vue_type_style_index_0_id_7e864fa8_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FrsModuleRoot_vue_vue_type_style_index_0_id_7e864fa8_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","distanceTo","inverse","NaN","initialBearingTo","initialBearing","finalBearingTo","finalBearing","destinationPoint","direct","finalBearingOn","cos2σM","sinσ","cosσ","Δσ","σʹ","φ1","λ1","α1","ellipsoid","sinα1","cosα1","tanU1","cosU1","sinU1","σ1","atan2","sinα","cosSqα","uSq","σ","iterations","φ2","L","λ2","α2","sinλ","cosλ","sinSqσ","λʹ","tanU2","cosU2","sinU2","lineIntersect","polyToLinestring","disjoint","geom1","geom2","compareCoords","isPointOnLine","isLineOnLine","isLineInPoly","isPolyInPoly","isPointOnLineSegment","lineString1","lineString2","doLinesIntersect","feature1","feature2","i2","LineSegmentStart","LineSegmentEnd","Point","dxc","dyc","dxl","dyl","cross","pair1","pair2","boolean","flatten1","flatten2","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_RedBorderPreview_vue_vue_type_style_index_0_lang_scss___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_RedBorderPreview_vue_vue_type_style_index_0_lang_scss___WEBPACK_IMPORTED_MODULE_0___default","convert","convertToMercator","convertToWgs84","lonLat","D2R","MAXEXTENT","adjusted","sign","xy","R2D","atan","exp","shim","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ListCard_vue_vue_type_style_index_0_id_234b201c_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ListCard_vue_vue_type_style_index_0_id_234b201c_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","process","useColors","window","document","documentElement","WebkitAppearance","firebug","exception","table","navigator","userAgent","parseInt","RegExp","$1","formatArgs","args","namespace","humanize","diff","color","lastC","call","save","namespaces","storage","removeItem","debug","load","NODE_ENV","BASE_URL","DEBUG","localstorage","localStorage","chrome","local","colors","formatters","err","message","enable","bounds","objects","x0","boundGeometry","boundGeometryType","GeometryCollection","boundPoint","MultiPoint","LineString","boundLine","arcs","MultiLineString","Polygon","MultiPolygon","boundMultiLine","hashset","size","hash","equal","empty","store","LN2","mask","add","collisions","has","values","hashmap","keyType","keyEmpty","valueType","keystore","valstore","set","matchKey","maybeSet","missingValue","point_equal","pointA","pointB","ArrayBuffer","floats","Float64Array","uints","Uint32Array","point_hash","topology","previousIndex","nextIndex","lines","rings","indexes","visitedByIndex","Int32Array","leftByIndex","rightByIndex","junctionByIndex","Int8Array","junctionCount","lineStart","lineEnd","sequence","ringStart","ringEnd","leftIndex","rightIndex","indexByPoint","hashIndex","equalIndex","junctionByPoint","cut","junctions","lineMid","0","1","ringMid","ringFixed","rotateArray","array","offset","arcCount","arcsByEnd","dedupLine","dedupRing","arc","startPoint","endPoint","startArcs","startArc","endArcs","endArc","equalLine","reverseEqualLine","equalRing","reverseEqualRing","findMinimumOffset","arcA","arcB","ia","ib","ja","jb","ka","kb","minimum","minimumPoint","delta","extract","extractGeometry","extractGeometryType","extractLine","extractRing","extractMultiRing","inputs","outputs","geomifyObject","geomifyFeatureCollection","geomifyFeature","geomifyGeometry","output","prequantize","kx","ky","quantizePoint","quantizePoints","pi","px","py","quantizeLine","quantizeRing","quantizePolygon","quantizeGeometry","quantizeGeometryType","translate","src_topology","quantization","transform","indexByArc","hashArc","equalArc","indexGeometry","indexGeometryType","indexArcs","indexMultiArcs","lineOverlap","GeojsonEquality","type1","type2","equality","overlap","coords1","coords2","coord1","coord2","segment1","segment2","area","polygons","pointsWithin","isInside","lineSliceAlong","lineDistance","sliceLineSegments","segmentLength","lineLength","numberOfSegments","outline","segment","gju","boundingBoxAroundPolyCoords","xAll","yAll","pnpoly","vert","lineStringsIntersect","intersects","a1","a2","b1","b2","ua_t","ub_t","u_b","ua","ub","pointInBoundingBox","pointInPolygon","poly","insideBox","insidePoly","pointInMultiPolygon","coords_array","numberToRadius","number","numberToDegree","drawCircle","radiusInMeters","centerPoint","radCenter","brng","asin","lng","rectangleCentroid","rectangle","xwidth","ywidth","pointDistance","pt1","pt2","lon1","lat1","lon2","lat2","dLat","dLon","geometryWithinRadius","simplify","source","kink","n_source","n_stack","n_dest","sig","dev_sqr","max_dev_sqr","band_sqr","x12","y12","d12","x13","y13","d13","x23","y23","d23","sig_start","sig_end","description","combinedDescription","class","inline","has-error","dirty","required","checked","has-success","ref","disabled","domProps","_i","change","$$a","$$el","$$c","$$v","$$i","_t","slot","$slots","_e","counter","BsCheckboxvue_type_script_lang_js_","LabelAndMessage","model","prop","event","state","tristate","lodash","$forceUpdate","reset","$refs","checkbox","indeterminate","mounted","bootstrap_BsCheckboxvue_type_script_lang_js_","booleanClockwise","rewind","rewindLineString","rewindPolygon","lineCoords","linear","linear_ab","v0","v1","tmp","linear_a","minV","maxV","linear_b","Options","polygons_full","linearRing","noQuadTree","isoBandOptions","userSettings","bandOptions","interpolate","interpolate_a","interpolate_b","isoLineOptions","lineOptions","cell2Polygons","pp","entry_coordinate","mode","skip_coordinate","requireFrame","lowerBound","upperBound","frameRequired","requireLineFrame","traceBandPaths","cellGrid","nextedge","ee","ve","enter","finalized","cc","dir","found_entry","valid_entries","add_x","add_y","available_starts","entry_dir","lb","lt","rt","rb","move","traceLinePaths","TreeNode","dx_tmp","dy_tmp","msb_x","msb_y","childA","childB","childC","childD","QuadTree","isoLines","useQuadTree","multiLine","tree","linePolygons","cellsBelowThreshold","prepareCell","isoBands","cellsInBand","subsumed","shapeCoordinates","square","triangle_bl","bottomleft","leftbottom","triangle_br","bottomright","rightbottom","triangle_tr","righttop","topright","triangle_tl","topleft","lefttop","tetragon_t","tetragon_r","tetragon_b","tetragon_l","tetragon_bl","tetragon_br","tetragon_tr","tetragon_tl","tetragon_lr","tetragon_tb","pentagon_tr","pentagon_tl","pentagon_br","pentagon_bl","pentagon_tr_rl","pentagon_rb_bt","pentagon_bl_lr","pentagon_lt_tb","pentagon_bl_tb","pentagon_lt_rl","pentagon_tr_bt","pentagon_rb_lr","hexagon_lt_tr","hexagon_bl_lt","hexagon_bl_rb","hexagon_tr_rb","hexagon_lt_rb","hexagon_bl_tr","heptagon_tr","heptagon_bl","heptagon_tl","heptagon_br","octagon","bandWidth","multiBand","bw","bandPolygons","prepareCell$1","computeCenterAverage","center_avg","union","coordsFrom","coordsTo","rhumbDistanceTo","scopedSlots","_u","fn","_v","proxy","enabledModel","enabled","rule","integer","unit","valueModel","bufferedFeature","previewFeatures","RedBorderPreviewvue_type_script_lang_js_","BsCheckbox","NumericInput","HelpBox","originalBorder","buffer_default","getters","rootState","rootGetters","geometry_RedBorderPreviewvue_type_script_lang_js_","envelopeIsEqual","envelopeContains","coordinatesEqual","multiPoint","envelope","_inside","hiIndex","reduce","high","iPrev","iNext","disc","toPolygon","testEdgeRing","shellList","testEnvelope","getEnvelope","minEnvelope","minShell","shell","tryEnvelope","testPoint","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_BsCheckbox_vue_vue_type_style_index_0_id_ca14c080_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_BsCheckbox_vue_vue_type_style_index_0_id_ca14c080_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","ext","tin","dissolve","removeDuplicates","cleaned","existing","maxEdge","tinPolys","pt3","dist1","dist2","dist3","dissolved","squareGrid","controlPoints","valueField","weight","cellWidth","filtered","samplingGrid","zw","sw","w","module-path","translation-namespaces","setup","loadPrerequisiteData","ZoneMapCreationvue_type_template_id_1887498b_scoped_true_lang_html_render","useRedBorder","original-border","borderGeometry","update:enabled","error","algorithmOptions","fields","algorithmFields","algorithm","minimumCorrelation","zoneCountOptions","allow-empty","placeholder","zoneCount","classLimit","outerClassLimit","fieldStates","selectedImageIds","validateOrderIdRule","orderId","mapCountForOrder","creating","isLoadingMapCount","small","large","cancel","quit","onCreate","requests","cultivations","ZoneMapCreationvue_type_template_id_1887498b_scoped_true_lang_html_staticRenderFns","ZoneMapCreationvue_type_script_lang_js_","FrsCultivationOverviewTable","TextInput","VueSelectize","IxButton","FrsLoadingIndicator","RedBorderPreview","mixins","FormPartMixin","DisableDefaultMapInteractionsMixin","vuex","text","$i18n","hasValidOrderId","_quit","$router","params","$route","_onCreate","_callee2","_context2","validate","validateSelectedImageIds","$nextTick","createZoneMap","infrastructure","success","t0","notifications_panel_coffee","finish","_x","$set","regex","ids","getMapCountForOrder","resetMapCount","zone_maps_ZoneMapCreationvue_type_script_lang_js_","ZoneMapCreation","SatelliteImageSelectionvue_type_template_id_b55de902_scoped_true_lang_html_render","image","shownImage","shownChannel","sortedImages","searchKeys","searchResult","searchText","channel","notVisibleCount","_l","sortedItems","item","selected","includes","active","shownImageId","toggle","toggleImage","nativeOn","onClick","date-range","scheduled-date-ranges","scheduledDateRanges","loadSatelliteImages","SatelliteImageSelectionvue_type_template_id_b55de902_scoped_true_lang_html_staticRenderFns","ChannelSelectorvue_type_template_id_9191524a_scoped_true_lang_html_render","dataSource","title","toggleButtonTitle","modelProxy","_s","ChannelSelectorvue_type_template_id_9191524a_scoped_true_lang_html_staticRenderFns","ChannelSelectorvue_type_script_lang_js_","ToggleButton","availableChannels","zone_maps_ChannelSelectorvue_type_script_lang_js_","ChannelSelector_component","ChannelSelector","FilterSelectorvue_type_template_id_cd193c48_scoped_true_lang_html_render","FilterSelectorvue_type_template_id_cd193c48_scoped_true_lang_html_staticRenderFns","FilterSelectorvue_type_script_lang_js_","availableFilters","zone_maps_FilterSelectorvue_type_script_lang_js_","FilterSelector_component","FilterSelector","SatImageLayervue_type_template_id_7d428daa_scoped_true_lang_html_render","layers","SatImageLayervue_type_template_id_7d428daa_scoped_true_lang_html_staticRenderFns","SatImageLayervue_type_script_lang_js_","IxWmsLayer","default","validator","baseUrl","sentinelHubPreviewInstances","recordingDate","layerPrefix","layerSuffix","zone_maps_SatImageLayervue_type_script_lang_js_","SatImageLayer_component","SatImageLayer","SatImageCardvue_type_template_id_99411b72_scoped_true_lang_html_render","format","readableDataSource","statistics","width","ndviMean","cloudMean","icon","SatImageCardvue_type_template_id_99411b72_scoped_true_lang_html_staticRenderFns","SatImageCardvue_type_script_lang_js_","ListCard","correctedNdvi","goodEnough","validForAuto","zone_maps_SatImageCardvue_type_script_lang_js_","SatImageCard_component","SatImageCard","LoadMoreButtonvue_type_template_id_2913f7ac_scoped_true_lang_html_render","dateRange","LoadMoreButtonvue_type_template_id_2913f7ac_scoped_true_lang_html_staticRenderFns","LoadMoreButtonvue_type_script_lang_js_","zone_maps_LoadMoreButtonvue_type_script_lang_js_","LoadMoreButton_component","LoadMoreButton","SatelliteImageSelectionvue_type_script_lang_js_","Search","FrsCurrentFieldBorderLayer","selectedImage","SatelliteImageSelectionvue_type_script_lang_js_objectSpread","images","satelliteImages","filteredImages","yearsWithCultivations","moment_default","year","items","nextDateRanges","imageId","setShownChannel","zone_maps_SatelliteImageSelectionvue_type_script_lang_js_","SatelliteImageSelection_component","SatelliteImageSelection","ZoneMapsModuleRootvue_type_script_lang_js_","FrsModuleRoot","then","bind","ZoneMapsModuleRootvue_type_script_lang_js_objectSpread","zone_maps_ZoneMapsModuleRootvue_type_script_lang_js_","ZoneMapsModuleRoot_component","truncate","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ChannelSelector_vue_vue_type_style_index_0_id_9191524a_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ChannelSelector_vue_vue_type_style_index_0_id_9191524a_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","lowLeft","topLeft","topRight","lowRight","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_LoadMoreButton_vue_vue_type_style_index_0_id_2913f7ac_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_LoadMoreButton_vue_vue_type_style_index_0_id_2913f7ac_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","marchingsquares","multiLineString","createIsoLines","breaks","propertiesToAllIsolines","propertiesPerIsoline","isolines","assign","isoline","rescaleIsolines","gridBbox","originalWidth","originalHeigth","matrixWidth","matrixHeight","scaleX","scaleY","resize","pointGrid","scaledIsolines","getSqDist","getSqSegDist","simplifyRadialDist","sqTolerance","prevPoint","newPoints","simplifyDPStep","first","last","simplified","maxSqDist","sqDist","simplifyDouglasPeucker","tolerance","highestQuality","earcut","holeIndices","dim","minX","minY","maxX","maxY","invSize","hasHoles","outerLen","outerNode","linkedList","eliminateHoles","earcutLinked","clockwise","signedArea","insertNode","equals","filterPoints","again","steiner","ear","pass","indexCurve","isEarHashed","isEar","cureLocalIntersections","splitEarcut","pointInTriangle","minTX","minTY","maxTX","maxTY","minZ","zOrder","maxZ","prevZ","nextZ","locallyInside","isValidDiagonal","splitPolygon","queue","getLeftmost","compareX","eliminateHole","hole","findHoleBridge","hx","hy","qx","mx","my","tanMin","sortLinked","tail","numMerges","pSize","qSize","inSize","leftmost","ax","ay","bx","by","cx","cy","intersectsPolygon","middleInside","q1","q2","an","bp","sum","deviation","polygonArea","trianglesArea","flatten","holes","dimensions","holeIndex","LatLonEllipsoidal","LatLonVectors","Vector3d","Dms","_m","SR_Common","Searching","localValue","onInput","focus","hasFocus","blur","onFocusLoss","clear","aria-hidden","SearchBarvue_type_script_lang_js_","InputClearButton","debounced","emitDebounced","emit","_value","created","search_SearchBarvue_type_script_lang_js_","createTopology","mergeTopology","merge","dissolveLineStrings","toArray","dissolvePolygons","geoms","topo","getHomogenousType","acc","flat","multiPolygon","clipPolygon","outRings","clipped","calcBbox","isPointInMultiPoint","isMultiPointInMultiPoint","multiPoint1","multiPoint2","matchFound","isMultiPointOnLine","haveFoundInteriorPoint","isMultiPointInPoly","polyBbox","lineBbox","doBBoxOverlap","midPoint","getMidpoint","poly1Bbox","poly2Bbox","bbox1","bbox2","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_NumericInput_vue_vue_type_style_index_0_id_505bcb48_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_NumericInput_vue_vue_type_style_index_0_id_505bcb48_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","processPolygon","polygonCoords","ptCoords","eprev","enext","rtan","ltan","nextCoordPair","isLeft","isBelow","isAbove","point1","point2","point3","pointCoords","polyCoords","out","degrees2radians","radians2degrees","coordinates1","longitude1","latitude1","bearing_rad","radians","latitude2","longitude2","simplepolygon","Airy1830","AiryModified","Bessel1841","Clarke1866","Clarke1880IGN","GRS80","Intl1924","WGS72","ED50","Irl1975","NAD27","NAD83","NTF","Potsdam","TokyoJapan","toDatum","oldLatLon","oldCartesian","toCartesian","newCartesian","applyTransform","newLatLon","eSq","ε2","R","tanβ","sinβ","cosβ","tx","ty","tz","s1","rx","ry","rz","dp","toLat","toLon","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SatelliteImageSelection_vue_vue_type_style_index_0_id_b55de902_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SatelliteImageSelection_vue_vue_type_style_index_0_id_b55de902_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","RADIUS","FLATTENING","POLAR_RADIUS","groups","multiMapping","memo","addToGroup","collectedProperties","rbush","bboxPolygon","maxEntries","remove","search","toBBox","collides","all","toJSON","fromJSON","json","cellSize","completelyWithin","xDistance","yDistance","columns","xFraction","yFraction","cellHeight","currentX","column","currentY","cellPoly","xi","yi","poly1","poly2","intersection","isEmpty","segmentIndex","started","heading","midpoint","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ZoneMapCreation_vue_vue_type_style_index_0_id_1887498b_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ZoneMapCreation_vue_vue_type_style_index_0_id_1887498b_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","coordsToLine","affineHull","linearlyIndependent","nhull","frame","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_node_modules_css_loader_index_js_ref_6_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_6_oneOf_1_2_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ToggleButton_vue_vue_type_style_index_0_lang_css___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_node_modules_css_loader_index_js_ref_6_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_6_oneOf_1_2_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ToggleButton_vue_vue_type_style_index_0_lang_css___WEBPACK_IMPORTED_MODULE_0___default","pSlice","objectKeys","isArguments","actual","expected","opts","Date","getTime","objEquiv","isUndefinedOrNull","isBuffer","copy","pointOnLine","startPt","stopPt","ends","startVertex","stopVertex","clipCoords","comboboxLabeledOption","escape","comboboxLabeledItem","Empty","Symbol","optionTemplate","group","src_vue_components_forms_input_base_LabelAndMessage__WEBPACK_IMPORTED_MODULE_13__","_components_forms_input_base_InputMixin__WEBPACK_IMPORTED_MODULE_16__","_components_forms_FormPartMixin__WEBPACK_IMPORTED_MODULE_17__","_components_forms_ChangeDetectionMixin__WEBPACK_IMPORTED_MODULE_18__","_components_forms_RuleMixin__WEBPACK_IMPORTED_MODULE_19__","multiple","maxItems","create","allowEmpty","ordered","sortField","useBodyAsParent","resetValue","_helpers_vuex__WEBPACK_IMPORTED_MODULE_14__","sanitizedFieldConfig","_helpers_objects__WEBPACK_IMPORTED_MODULE_15__","sanitizedMaxItems","selectize","select","internalOptions","sortedOptions","lodash__WEBPACK_IMPORTED_MODULE_11__","resolveField","convertOption","emptyOption","$order","SR_InfoMessages","NoSelection","internalGroups","C_src_Solutions_WebApp_node_modules_babel_runtime_corejs2_helpers_esm_typeof__WEBPACK_IMPORTED_MODULE_4__","option","internalItems","correspondingOptions","invalidIndices","ruleDescription","builtinMessages","RequiredField","combinedMessages","ruleMessages","states","ruleState","combineStates","field","resolve","mapping","fieldValue","getOption","onSelectionChanged","_this7","$_VueSelectize_internalUpdate","selectedItems","finalSelection","updateValues","onSelectChanged","evt","preventDefault","onType","updateOptions","_this8","clearOptions","addOption","refreshOptions","clearOptionGroups","addOptionGroup","_this9","addItem","setDisable","disable","_this10","optgroupField","selectOnTab","PleaseSelectSomething","allowEmptyOption","dropdownParent","searchField","plugins","remove_button","$select","$","$maxSelectionInfo","prependTo","src_js_i18n__WEBPACK_IMPORTED_MODULE_12__","addClass","removeClass","beforeDestroy","off","destroy","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_IxWmsLayer_vue_vue_type_style_index_0_id_41702c76_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_IxWmsLayer_vue_vue_type_style_index_0_id_41702c76_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","turfUnion","booleanOverlap","turfbbox","Rbush","getClosest","toLinestring","flat_arr","propertyName","originalIndexOfItemsRemoved","treeItems","rtree","polyIndex","inputFeatureBbox","treeObj","origIndexPosition","polyBoundingBox","searchObj","potentialMatchingFeatures","featureChanged","searchIndex","matchFeaturePosition","closestNumber","greaterNumber","matchFeature","overlapCheck","polyClone","polyBeingCheckedClone","linestring1","linestring2","newBoundingBox","inRing","ignoreBoundary","xj","yj","onBoundary","inBBox","polys","inHole","startDist","stopDist","overshot","interpolated","travelled","xSum","ySum","crossProduct","v2","sub","scalarMult","intersectSegments","qmp","numerator","isParallel","stack","NULL_ORDINATE","dimensionsToTest","array_","addAll","ensureCapacity","minx","maxx","miny","maxy","init","S","interfaces_","T","P","O","_","SRID","userData","getSRID","Y","U","H","W","K","Z","Q","J","$s","tt","parent","et","nt","it","root_","size_","st","ot","at","ut","ht","ct","ft","hasNullElements","gt","dt","geomFact","bnRule","endpointMap","MOD2_BOUNDARY_RULE","getFactory","vt","mt","yt","xt","Et","It","Nt","Ct","St","wt","Lt","Rt","Tt","createLinearRing","hasNonEmptyElements","Pt","bt","ie","getCoordinateSequenceFactory","validateConstruction","Ot","isUserDataCopied","Mt","Dt","At","Ft","Gt","isInteger","fill","getDimension","getCoordinateCopy","qt","Bt","zt","_keys","_values","_itp","objectOnly","Vt","Jt","kt","no","Yt","Ut","Xt","Ht","Wt","jt","Qt","Kt","Zt","done","$t","entries","te","map_","so","modelType","FLOATING","ne","FIXED","setScale","nameToTypeMap","put","precisionModel","coordinateSequenceFactory","getDefaultCoordinateSequenceFactory","re","geometryFactory","se","parser","oe","inputLines","intPt","intLineIndex","_isProper","pa","ae","ue","le","crossingCount","isPointOnSegment","he","ce","p0","fe","setAll","FALSE","INTERIOR","BOUNDARY","EXTERIOR","ge","areaBasePt","triangleCent3","areasum2","cg3","lineCentSum","totalLength","ptCount","ptCentSum","pe","treeSet","me","geomFactory","inputPts","extractCoordinates","filterCoordinates","ye","xe","inputGeom","pruneEmptyGeometry","preserveGeometryCollectionType","preserveCollections","preserveType","Ee","snapTolerance","srcPts","seg","allowSnappingToSourceVertices","_isClosed","getCoordinates","isClosed","Ie","srcGeom","Ne","snapPts","isSelfSnap","Ce","isFirst","commonMantissaBitsCount","commonBits","commonSignExp","Se","commonCoord","ccFilter","we","commonBitsX","commonBitsY","Le","trans","Re","atStart","subcollectionIterator","getNumGeometries","Te","boundaryRule","OGC_SFS_BOUNDARY_RULE","isIn","numBoundaries","Pe","be","Oe","pts","Me","De","_size","Ae","Fe","Ge","childBoundables","level","qe","boundable1","boundable2","_distance","itemDistance","Be","built","itemBoundables","nodeCapacity","DEFAULT_NODE_CAPACITY","isTrue","ze","Ve","ke","Ye","Ue","Xe","segString","segmentOctant","_isInterior","equals2D","getCoordinate","He","nodeMap","We","nodeList","nodeIt","currNode","nextNode","currSegIndex","getEdge","iterator","readNextNode","je","Ke","Ze","tempEnv1","tempEnv2","overlapSeg1","overlapSeg2","Qe","env","Je","$e","tn","segInt","setSegmentIntersector","nn","monoChains","idCounter","nodedSegStrings","nOverlaps","rn","si","sn","msgWithCoord","findAllIntersections","isCheckEndSegmentsOnly","li","interiorIntersection","intSegments","intersections","intersectionCount","keepIntersections","un","segStrings","_isValid","ln","toSegmentStrings","hn","mapOp","cn","location","ON","LEFT","RIGHT","gn","elt","NONE","setLocation","setLocations","dn","startDe","maxNodeDegree","_isHole","computePoints","computeRing","pn","vn","mn","_isInResult","_isCovered","_isCoveredSet","_isVisited","yn","xn","nodeFact","En","quadrant","In","_isForward","nextMin","minEdgeRing","depth","getNumPoints","computeDirectedLabel","Nn","Cn","edgeEndList","Sn","wn","op","ptLocator","lineEdgesList","resultLineList","Ln","resultPointList","Rn","Tn","Pn","edgeMap","edgeList","ptInAreaLocation","bn","resultAreaEdgeList","SCANNING_FOR_INCOMING","LINKING_TO_OUTGOING","On","_n","mce","chainIndex","Mn","xValue","eventType","insertEvent","deleteEventIndex","DELETE","INSERT","Dn","An","_hasIntersection","hasProper","hasProperInterior","properIntersectionPoint","includeProper","recordIsolated","isSelfIntersection","numIntersections","numTests","bdyNodes","_isDone","isDoneWhenProperInt","Fn","events","Gn","POSITIVE_INFINITY","NEGATIVE_INFINITY","qn","Bn","zn","node1","node2","buildExtent","Vn","leaves","isForcedToLineString","Yn","Un","Hn","Xn","Wn","jn","Kn","Zn","startIndex","env1","env2","getChainStartIndices","Qn","NULL_VALUE","Jn","eiList","_isIsolated","depthDelta","$n","parentGeom","lineEdgeMap","boundaryNodeRule","useBoundaryDeterminationRule","argIndex","boundaryNodes","_hasTooFewPoints","invalidPoint","areaPtLocator","ti","resultPrecisionModel","arg","setComputationPrecision","getPrecisionModel","compareTo","ei","_orientation","orientation","ni","ocaMap","ii","resultGeom","resultPolyList","ri","cbr","computeSnapTolerance","oi","interiorPoint","maxWidth","centreY","hiY","MAX_VALUE","loY","getEnvelopeInternal","getMaxY","getMinY","avg","ui","minDistance","getCentroid","addInterior","addEndpoints","selectedSegment","ci","subnode","fi","gi","di","32","64","isFinite","interval","computeKey","vi","centre","getMin","getMax","mi","minExtent","Ei","Ii","crossings","buildIndex","Ni","mcp","Ci","Si","wi","extremalPts","Li","isConvex","convexHullPts","minBaseSeg","minWidthPt","minPtIndex","minWidth","Ri","distanceTolerance","Ti","Pi","_orig","_sym","_next","_isMarked","Oi","vertexMap","_isStart","Mi","Di","nodeEdgeStack","ringStartEdge","Ai","Fi","Gi","centrex","centrey","getMinX","getMaxX","qi","Bi","zi","Vi","ki","Yi","Ui","Xi","ol","Hi","noder","scaleFactor","offsetX","offsetY","isScaled","isIntegerPrecision","Wi","isClosedEndpointsInInterior","nonSimpleLocation","isInBoundary","ji","Ki","quadrantSegments","DEFAULT_QUADRANT_SEGMENTS","endCapStyle","CAP_ROUND","joinStyle","JOIN_ROUND","mitreLimit","DEFAULT_MITRE_LIMIT","_isSingleSided","simplifyFactor","DEFAULT_SIMPLIFY_FACTOR","setQuadrantSegments","setEndCapStyle","setJoinStyle","setMitreLimit","Zi","minIndex","minCoord","minDe","orientedDe","Qi","Ji","finder","dirEdgeList","rightMostCoord","$i","inputLine","distanceTol","isDeleted","angleOrientation","COUNTERCLOCKWISE","ptList","minimimVertexDistance","er","maxCurveSegmentError","filletAngleQuantum","closingSegLengthFactor","segList","bufParams","s0","s2","seg0","seg1","offset0","offset1","side","_hasNarrowConcaveAngle","getQuadrantSegments","getJoinStyle","MAX_CLOSING_SEG_LEN_FACTOR","nr","ir","subgraphs","cga","rr","upwardSeg","leftDepth","sr","curveBuilder","curveList","or","hasInterior","numInteriorIntersections","numProperIntersections","ar","workingPrecisionModel","workingNoder","ur","lr","originalPt","ptScaled","p0Scaled","p1Scaled","corner","safeEnv","initCorners","hr","cr","hotPixel","parentEdge","hotPixelVertexIndex","_isNodeAdded","fr","interiorIntersections","gr","pm","pointSnapper","setPrecisionModel","getScale","dr","argGeom","resultGeometry","saveException","pr","comps","vr","segIndex","INSIDE_AREA","mr","yr","locations","xr","terminateDistance","minDistanceLocation","Er","directedEdges","Ir","Nr","edgeDirection","angle","Cr","Sr","dirEdge","setDirectedEdges","wr","outEdges","sorted","Lr","deStar","Rr","Tr","Pr","dirEdges","Or","mergedLineStrings","edgeStrings","_r","Mr","Dr","geomGraph","disconnectedRingcoord","Ar","Fr","edgeEnds","getDirectedCoordinate","getLabel","Gr","qr","Br","zr","Vr","nodeGraph","kr","totalEnv","nestedPt","Yr","errorType","Ur","parentGeometry","isSelfTouchingRingFormingHoleValid","validErr","Xr","deList","lowestEdge","ringPts","_isProcessed","_isIncludedSet","_isIncluded","Hr","Wr","jr","lineStringAdder","Kr","dangles","cutEdges","invalidRingLines","holeList","polyList","isCheckingRingsValid","extractOnlyPolygonal","Zr","im","isolatedEdges","Qr","rectEnv","Jr","diagUp0","diagUp1","diagDown0","diagDown1","$r","es","_intersects","ns","rectSeq","_containsPoint","getExteriorRing","getCoordinateSequence","is","rectIntersector","hasIntersection","rs","_relate","ss","skipEmpty","inputGeoms","extractFactory","os","pointGeom","otherGeom","sortIndex","us","inputPolys","ls","hs","CoordinateOperation","targetPM","removeCollapsed","cs","changePrecisionModel","isPointwise","fs","usePt","gs","isEnsureValidTopology","ds","ps","vs","parentLine","segs","resultSegs","minimumSize","ys","querySeg","xs","inputIndex","outputIndex","linePts","Es","Is","lineSimplifier","linestringMap","Ns","Cs","tps","Ss","segLen","splitPt","minimumLen","getLength","ws","Ls","Rs","Ts","Ps","_isOnConstraint","constraint","_rot","vertex","Os","subdiv","isUsingTolerance","getTolerance","Ms","lastEdge","Ds","msgWithSpatial","As","Fs","visitedKey","quadEdges","startingEdge","edgeCoincidenceTolerance","frameVertex","frameEnv","locator","triEdges","EDGE_COINCIDENCE_TOL_FACTOR","createFrame","initSubdiv","Gs","qs","triList","Bs","zs","coordList","triCoords","Vs","ks","Ys","Us","numberOfNodes","Xs","matchNode","matchDist","Hs","initialVertices","segVertices","segments","incDel","splitFinder","kdt","vertexFactory","computeAreaEnv","Ws","siteCoords","js","constraintLines","constraintVertexMap","Ks","clipEnv","diagramEnv","Zs","trunc","getClass","equalsWithTolerance","doubleToLongBits","longBitsToDouble","isInfinite","shouldNeverReachHere","setOrdinate","getOrdinate","equals3D","equalInZ","CloneNotSupportedException","distance3D","hashCode","setCoordinate","DimensionalComparator","serialVersionUID","hasNext","Qs","arrayList_","position_","toCoordinateArray","coordArrayType","closeRing","getArea","getWidth","getHeight","isNull","covers","expandToInclude","setToNull","maxExtent","expandBy","contains","toLocationSymbol","log10","LOG_10","clamp","append","setCharAt","substr","intValue","isWhitespace","extractSignificantDigits","magnitude","TEN","divide","ONE","multiply","MAX_PRINT_DIGITS","subtract","valueOf","selfAdd","sqr","doubleValue","negate","isZero","selfSubtract","getSpecialNumberString","selfDivide","SPLIT","dump","createNaN","selfMultiply","reciprocal","rint","setValue","isNegative","selfSqr","toStandardNotation","toSciNotation","stringOfChar","SCI_NOT_ZERO","SCI_NOT_EXPONENT_CHAR","IllegalStateException","substring","isPositive","signum","isDigit","NumberFormatException","TWO_PI","PI_2","EPS","orientationIndexFilter","signOfDet2x2","DP_SAFE_EPSILON","getX","expandEnvelope","getY","arraycopy","getProperty","line.separator","getSortIndex","SORTINDEX_GEOMETRYCOLLECTION","getGeometryN","isRectangle","equalsTopo","equalsExact","geometryChanged","geometryChangedFilter","geometryChangedAction","equalsNorm","norm","compareToSameClass","getUserData","toGeometry","checkNotGeometryCollection","computeEnvelopeInternal","setSRID","setUserData","isGeometryCollectionOrDerived","SORTINDEX_MULTIPOINT","SORTINDEX_MULTILINESTRING","SORTINDEX_MULTIPOLYGON","SORTINDEX_POINT","SORTINDEX_LINESTRING","SORTINDEX_LINEARRING","SORTINDEX_POLYGON","Mod2BoundaryNodeRule","EndPointBoundaryNodeRule","MultiValentEndPointBoundaryNodeRule","MonoValentEndPointBoundaryNodeRule","ENDPOINT_BOUNDARY_RULE","MULTIVALENT_ENDPOINT_BOUNDARY_RULE","MONOVALENT_ENDPOINT_BOUNDARY_RULE","isRing","ptNotInList","scroll","hasRepeatedPoints","removeRepeatedPoints","removeNull","copyDeep","isEqualReversed","atLeastNCoordinatesOrNothing","increasingDirection","minCoordinate","OLDcompare","ForwardComparator","BidirectionalComparator","entrySet","javascript","util","OperationNotSupported","Js","hashSet_","getValue","getKey","fixAfterInsertion","rotateLeft","rotateRight","getFirstEntry","successor","eo","treeSet_","asList","toDimensionSymbol","SYM_FALSE","TRUE","SYM_TRUE","DONTCARE","SYM_DONTCARE","SYM_P","SYM_L","SYM_A","toDimensionValue","isDone","isGeometryChanged","isEquivalentClass","getBoundaryDimension","createGeometryCollection","getBoundary","getGeometryType","createMultiLineString","boundaryMultiLineString","getEmptyMultiPoint","computeBoundaryCoordinates","createPoint","createMultiPointFromCoords","boundaryLineString","getStartPoint","createMultiPoint","getEndPoint","addEndpoint","getCoordinateN","chars","getStackTrace","printStackTrace","readLine","NEWLINE","SIMPLE_ORDINATE_FORMAT","spaces","copyCoord","extend","swap","ensureValidRing","createClosedRing","isSimple","getPointN","computeLength","createLineString","isCoordinate","getNumInteriorRing","isCCW","getInteriorRingN","isValid","MINIMUM_VALID_SIZE","createMultiPolygon","setCopyUserData","edit","editInternal","editGeometryCollection","editPolygon","getName","createPolygon","GeometryEditorOperation","editCoordinates","NoOpGeometryOperation","CoordinateSequenceOperation","readResolve","instanceObject","ro","delete","Map","getMaximumSignificantDigits","isFloating","FLOATING_SINGLE","getType","makePrecise","mostPrecise","Type","maximumPreciseValue","buildGeometry","toGeometryArray","toPolygonArray","toLineStringArray","toPointArray","createGeometry","toMultiPolygonArray","toMultiLineStringArray","toMultiPointArray","toLinearRingArray","createPointFromInternalCoord","oo","typeStr","emptyTypeStr","parenComma","doubleParenComma","trimParens","uo","ao","multipoint","linearring","multilinestring","multipolygon","geometrycollection","toLineString","getIndexAlongSegment","computeIntLineIndex","getTopologySummary","isEndPoint","isCollinear","computeIntersection","computeIntersect","getIntersectionNum","getEdgeDistance","isProper","isInteriorIntersection","getIntersection","NO_INTERSECTION","computeEdgeDistance","COLLINEAR_INTERSECTION","getEndpoint","isIntersection","getIntersectionAlongSegment","nonRobustComputeEdgeDistance","DONT_INTERSECT","DO_INTERSECT","COLLINEAR","POINT_INTERSECTION","isInSegmentEnvelopes","normalizeToMinimum","smallestInAbsValue","safeHCoordinateIntersection","nearestEndpoint","intersectionWithNormalization","checkDD","println","normalizeToEnvCentre","computeCollinearIntersection","distancePointLine","countSegment","isPointInPolygon","getLocation","isOnSegment","locatePointInRing","distanceLineLine","isPointInRing","computeOrientation","distancePointLinePerpendicular","isOnLine","CLOCKWISE","STRAIGHT","isVertical","project","projectionFactor","distancePerpendicular","closestPoints","closestPoint","lineIntersection","pointAlongOffset","setCoordinates","segmentFraction","isHorizontal","pointAlong","java","lang","Double","isIntersects","isDisjoint","isCovers","isCoveredBy","isContains","setAtLeast","setAtLeastIfValid","isWithin","isTouches","isOverlaps","isEquals","transpose","matches","isCrosses","freeze","Coordinate","CoordinateList","Envelope","LineSegment","GeometryFactory","Geometry","LinearRing","Dimension","IntersectionMatrix","PrecisionModel","addPoint","setBasePoint","addLineSegments","addHole","addTriangle","addShell","centroid3","area2","IndexOutOfBoundsException","peek","preSort","computeOctRing","computeOctPts","lineOrPolygon","cleanRing","isBetween","padArray3","getConvexHull","grahamScan","polarCompare","RadialComparator","transformPoint","transformCoordinates","transformPolygon","transformLinearRing","createCoordinateSequence","getInputGeometry","transformMultiLineString","transformLineString","transformMultiPoint","transformMultiPolygon","transformGeometryCollection","snapVertices","findSnapForVertex","snapTo","snapSegments","findSegmentIndexToSnap","setAllowSnappingToSourceVertices","extractTargetCoordinates","snapToSelf","computeMinimumSegmentLength","snap","computeOverlaySnapTolerance","computeSizeBasedSnapTolerance","SNAP_PRECISION_FACTOR","snapLine","getCommon","signExpBits","numCommonMostSigMantissaBits","zeroLowerBits","Long","toBinaryString","getBit","addCommonBits","removeCommonBits","getCommonCoordinate","CommonCoordinateFilter","Translater","isAtomic","UnsupportedOperationException","locateInternal","locateInPolygonRing","locate","updateLocationInfo","computeLocation","octant","setData","getData","getSegmentOctant","getBounds","getItem","poll","reorder","visitItem","query","getLevel","getChildBoundables","addChildBoundable","computeBounds","ho","reverseOrder","singletonList","expandToQueue","isComposite","expand","isLeaves","getDistance","getBoundable","getNodeCapacity","lastNode","build","itemsTree","boundablesAtLevel","getIntersectsOp","createNode","createHigherLevels","getRoot","createParentBoundables","getComparator","compareDoubles","IntersectsOp","createParentBoundablesFromVerticalSlices","createParentBoundablesFromVerticalSlice","intersectsOp","verticalSlices","yComparator","xComparator","nearestNeighbour","centreX","STRtreeNode","relativeSign","compareValue","print","isInterior","getSplitCoordinates","addEdgeCoordinates","addCollapsedNodes","findCollapsesFromInsertedNodes","findCollapsesFromExistingVertices","addSplitEdges","createSplitEdge","findCollapseIndex","checkSplitEdgesCorrectness","addIntersection","safeOctant","addIntersectionNode","getNodeList","addIntersections","getNodedSubstrings","getLineSegment","computeSelect","computeOverlaps","computeOverlapsInternal","setId","getEndIndex","getStartIndex","getContext","getId","isNorthern","NE","NW","isOpposite","commonHalfPlane","isInHalfPlane","SE","SW","findChainEnd","toIntArray","getChains","computeNodes","getMonotoneChains","getIndex","intersectChains","processIntersections","SegmentOverlapAction","getInteriorIntersection","setCheckEndSegmentsOnly","getIntersectionSegments","getIntersections","setFindAllIntersections","setKeepIntersections","isEndSegment","createAllIntersectionsFinder","createAnyIntersectionFinder","createIntersectionCounter","execute","checkInteriorIntersections","checkValid","getErrorMessage","computeIntersections","setAllLocations","setAllLocationsIfNull","isLine","getLocations","isArea","isAnyNull","isEqualOnSide","allPositionsEqual","getGeometryCount","toLine","toLineLabel","isIsolated","getEdgeRing","mergeLabel","addPoints","isForward","setEdgeRing","getNext","getLinearRing","computeMaxNodeDegree","getEdges","getOutgoingDegree","isHole","setInResult","containsPoint","isShell","getMaxNodeDegree","getShell","setShell","setMinEdgeRing","getNextMin","buildMinimalRings","getMinEdgeRing","linkDirectedEdgesForMinimalEdgeRings","linkMinimalDirectedEdges","setVisited","isCovered","isCoveredSet","setLabel","setCovered","updateIM","computeIM","isInResult","isVisited","isIncidentEdgeInResult","computeMergedLocation","setNode","setLabelBoundary","addNode","getBoundaryNodes","compareDirection","getDy","lastIndexOf","getDx","getQuadrant","computeLabel","getDepth","setDepth","isInteriorAreaEdge","setNextMin","getDepthDelta","isLineEdge","getSym","printEdge","printReverse","setSym","setVisitedEdge","setEdgeDepths","setNext","depthFactor","printEdges","getNodeIterator","linkResultDirectedEdges","debugPrintln","isBoundaryNode","linkAllDirectedEdges","matchInSameDirection","getEdgeEnds","debugPrint","getEdgeIterator","findEdgeInSameDirection","insertEdge","findEdgeEnd","addEdges","getNodes","findEdge","sortShellsAndHoles","computePolygons","placeFreeHoles","findEdgeRingContaining","buildMinimalEdgeRings","findShell","placePolygonHoles","buildMaximalEdgeRings","getPolygons","collectLines","getGraph","collectLineEdge","collectBoundaryTouchEdge","labelIsolatedLine","getArgGeometry","findCoveredLineEdges","buildLines","isResultOfOp","isCoveredByA","labelIsolatedLines","INTERSECTION","filterCoveredNodeToPoint","isCoveredByLA","extractNonCoveredResultNodes","getDegree","containsPointInPolygon","getNextCW","propagateSideLabels","isAreaLabelsConsistent","computeEdgeEndLabels","getBoundaryNodeRule","checkAreaLabelsConsistent","findIndex","getGeometry","computeLabelling","insertEdgeEnd","getResultAreaEdges","getRightmostEdge","updateLabelling","computeDepths","mergeSymLabels","computeIntersectsForChain","isDelete","setDeleteEventIndex","getObject","getInsertEvent","isInsert","isSameLabel","getDeleteEventIndex","isTrivialIntersection","isAdjacentSegments","getProperIntersectionPoint","setIsDoneIfProperInt","hasProperInteriorIntersection","isBoundaryPointInternal","hasProperIntersection","isBoundaryPoint","setBoundaryNodes","setIsolated","prepareEvents","processOverlaps","getMonotoneChainEdge","getStartIndexes","NodeComparator","buildTree","IntervalRTreeNode","buildLevel","buildRoot","printNode","setForceToLineString","getLines","getItems","addLine","SegmentVisitor","IntervalIndexedGeometry","getSegmentIndex","computeIntersects","getDelta","depthAtLocation","getCollapsedEdge","setName","isCollapsed","getMaximumSegmentIndex","isPointwiseEqual","setDepthDelta","getEdgeIntersectionList","insertBoundaryPoint","determineBoundary","computeSelfNodes","createEdgeSetIntersector","addSelfIntersectionNodes","computeSplitEdges","computeEdgeIntersections","hasTooFewPoints","insertPoint","addPolygon","addPolygonRing","addLineString","getInvalidPoint","getBoundaryPoints","addSelfIntersectionNode","addCollection","compareOriented","findEdgeIndex","findEqualEdge","insertUniqueEdge","cancelDuplicateResultEdges","computeGeometry","createEmptyResult","replaceCollapsedEdges","updateNodeLabelling","getResultGeometry","computeOverlay","insertUniqueEdges","copyPoints","computeLabelsFromDepths","labelIncompleteNodes","findResultAreaEdges","labelIncompleteNode","overlayOp","MapOp","symDifference","SYMDIFFERENCE","resultDimension","UNION","DIFFERENCE","difference","selfSnap","prepareResult","horizontalBisector","widestGeometry","getInteriorPoint","getBisectorY","updateInterval","SafeBisectorFinder","hasChildren","isPrunable","hasItems","addAllItems","addAllItemsFromOverlapping","isSearchMatch","nodeSize","getSubnodeIndex","overlaps","exponent","powerOf2","getInterval","computeLevel","computeInterval","getPoint","createSubnode","getSubnode","createExpanded","isZeroWidth","MIN_BINARY_EXPONENT","insertContained","collectStats","ensureExtent","testLineSegment","testMonotoneChain","MCSelecter","PI_TIMES_2","isAcute","isObtuse","interiorAngle","normalizePositive","angleBetween","getTurn","angleBetweenOriented","PI_OVER_2","PI_OVER_4","interpolateZ","longestSideLength","circumcentre","area3D","inCentre","perpendicularBisector","angleBisector","getRadius","compute","getDiameter","getExtremalPoints","computeCirclePoints","lowestPoint","pointWitMinAngleWithX","pointWithMinAngleWithSegment","computeCentre","getFarthestPoints","getCircle","getCentre","getWidthCoordinate","computeMinimumDiameter","getSupportingSegment","computeWidthConvex","computeConvexRingMinDiameter","findMaxPerpDistance","getMinimumRectangle","computeC","computeSegmentForLine","getMinimumDiameter","co","Centroid","CGAlgorithms","ConvexHull","InteriorPointArea","InteriorPointLine","InteriorPointPoint","RobustLineIntersector","MCPointInRing","MinimumBoundingCircle","MinimumDiameter","setDistanceTolerance","densifyPoints","densify","createValidArea","DensifyTransformer","fo","Densifier","dest","oNext","insertAfter","orig","deltaY","compareAngularDirection","deltaX","prevNode","setMark","isMarked","setMarkBoth","markBoth","createEdge","isValidEdge","getVertexEdges","setStart","isStart","updateRingStartEdge","getResult","computeResult","stackEdges","buildRing","buildLine","go","LineDissolver","po","GeometryGraph","getNodeCount","visitItems","visit","computeQuadLevel","queryAll","vo","Quadtree","mo","STRtree","yo","quadtree","strtree","xo","Eo","Io","Feature","FeatureCollection","reducePrecision","convertFromPoint","convertFromLineString","convertFromLinearRing","convertFromPolygon","convertFromMultiPoint","convertFromMultiLineString","convertFromMultiPolygon","convertFromCollection","getLinearRings","getPoints","getLineStrings","getGeometries","convertToPoint","convertToLineString","convertToLinearRing","convertToPolygon","convertToMultiPoint","convertToMultiLineString","convertToMultiPolygon","convertToCollection","No","OL3Parser","WKTReader","WKTWriter","rescale","Co","MCIndexNoder","ScaledNoder","SegmentString","isSimpleMultiPoint","isSimplePolygonal","isSimpleLinearGeometry","hasClosedEndpointIntersection","getNonSimpleLocation","hasNonEndpointIntersection","computeSimple","isSimpleGeometryCollection","EndpointInfo","getEndCapStyle","isSingleSided","JOIN_BEVEL","JOIN_MITRE","setSimplifyFactor","getSimplifyFactor","getMitreLimit","setSingleSided","bufferDistanceError","CAP_FLAT","CAP_SQUARE","getRightmostSide","getRightmostSideOfSegment","checkForRightmostCoordinate","findRightmostEdgeAtVertex","findRightmostEdgeAtNode","addLast","removeFirst","shift","clearVisitedEdges","getRightmostCoordinate","computeNodeDepth","copySymDepths","computeDepth","addReachable","findResultEdges","getDirectedEdges","isDeletable","isConcave","isShallow","isShallowSampled","deleteShallowConcavities","findNextNonDeletedIndex","isShallowConcavity","NUM_PTS_TO_CHECK","collapseLine","INIT","KEEP","COORDINATE_ARRAY_TYPE","addPt","isRedundant","addPts","setMinimumVertexDistance","addNextSegment","computeOffsetSegment","addCollinear","addOutsideTurn","addInsideTurn","addLineEndCap","addFilletArc","addMitreJoin","addLimitedMitreJoin","addFilletCorner","OFFSET_SEGMENT_SEPARATION_FACTOR","addBevelJoin","createSquare","addSegments","addFirstSegment","addLastSegment","initSideSegments","INSIDE_TURN_VERTEX_SNAP_DISTANCE_FACTOR","createCircle","CURVE_VERTEX_SNAP_DISTANCE_FACTOR","hasNarrowConcaveAngle","getOffsetCurve","getSegGen","computePointCurve","computeOffsetCurve","computeSingleSidedBufferCurve","simplifyTolerance","computeRingBufferCurve","computeLineBufferCurve","getLineCurve","getBufferParameters","getRingCurve","copyCoordinates","findStabbedSegments","DepthSegment","addCurve","isErodedCompletely","isTriangleErodedCompletely","getCurves","getLineIntersector","hasInteriorIntersection","setWorkingPrecisionModel","buildSubgraphs","createSubgraphs","createEmptyResultGeometry","getNoder","computeNodedEdges","setNoder","convertSegStrings","checkEndPtVertexIntersections","checkCollapses","checkCollapse","fact","intersectsScaled","intersectsToleranceSquare","copyScaled","getSafeEnvelope","SAFE_ENV_EXPANSION_FACTOR","intersectsPixelClosure","addSnappedNode","isNodeAdded","HotPixelSnapAction","getInteriorIntersections","checkCorrectness","snapRound","findInteriorIntersections","computeIntersectionSnaps","computeVertexSnaps","bufferFixedPrecision","bufferReducedPrecision","MAX_PRECISION_DIGITS","precisionScaleFactor","bufferOriginalPrecision","bufferOp","CAP_BUTT","So","BufferOp","BufferParameters","isInsideArea","getGeometryComponent","computeContainmentDistance","computeMinDistanceLinesPoints","computeMinDistance","computeFacetDistance","computeMinDistanceLines","updateMinDistance","computeMinDistancePoints","nearestLocations","nearestPoints","isWithinDistance","wo","DistanceOp","getEdgeDirection","getLine","setMarked","setContext","getComponentWithVisitedState","isRemoved","getDirectionPt","getAngle","getFromNode","setEdge","getToNode","toEdges","getOutEdges","addOutEdge","getDirEdge","getOppositeNode","getNextEdge","sortEdges","getNextCWEdge","getEdgesBetween","retainAll","findNodesOfDegree","nodeIterator","dirEdgeIterator","edgeIterator","findNode","buildEdgeStringsForUnprocessedNodes","buildEdgeStringsStartingAt","buildEdgeStringsForNonDegree2Nodes","buildEdgeStringsForObviousStartNodes","getMergedLineStrings","buildEdgeStringStartingWith","buildEdgeStringsForIsolatedLoops","Lo","LineMerger","Ro","OverlayOp","isInRing","setRing","getRing","visitInteriorRing","findDifferentPoint","visitLinkedDirectedEdges","visitShellInteriors","setInteriorEdgesInResult","buildEdgeRings","hasUnvisitedShellEdge","isInteriorsConnected","createEdgeEndForNext","createEdgeEndForPrev","computeEdgeEnds","computeLabelOn","computeLabelSide","computeLabelSides","updateIMFromEdges","insertEdgeEnds","copyNodesAndLabels","computeIntersectionNodes","isNodeEdgeAreaLabelsConsistent","hasDuplicateRings","isNodeConsistentArea","getNestedPoint","isNonNested","findPtNotNode","getErrorType","getMessage","errMsg","ERROR","REPEATED_POINT","HOLE_OUTSIDE_SHELL","NESTED_HOLES","DISCONNECTED_INTERIOR","SELF_INTERSECTION","RING_SELF_INTERSECTION","NESTED_SHELLS","DUPLICATE_RINGS","TOO_FEW_POINTS","INVALID_COORDINATE","RING_NOT_CLOSED","checkInvalidCoordinates","checkHolesNotNested","checkConsistentArea","checkShellInsideHole","checkNoSelfIntersectingRings","checkNoSelfIntersectingRing","checkConnectedInteriors","checkHolesInShell","checkTooFewPoints","getValidationError","checkClosedRing","checkClosedRings","checkShellsNotNested","setSelfTouchingRingFormingHoleValid","checkShellNotNested","isIncluded","isIncludedSet","isOuterHole","hasShell","getPolygon","isProcessed","setIncluded","getOuterHole","computeHole","isOuterShell","getLineString","updateIncluded","setProcessed","findDirEdgesInRing","EnvelopeComparator","findEdgeRing","computeDepthParity","computeNextCWEdges","deleteCutEdges","findLabeledEdgeRings","getEdgeRings","convertMaximalToMinimalEdgeRings","findIntersectionNodes","computeNextCCWEdges","deleteDangles","deleteAllEdges","getDegreeNonDeleted","polygonize","getInvalidRingLines","findValidRings","findShellsAndHoles","assignHolesToShells","findDisjointShells","extractPolygons","getDangles","getCutEdges","setCheckRingsValid","findOuterShells","assignHoleToShell","LineStringAdder","To","Polygonizer","computeProperIntersectionIM","labelIsolatedEdges","labelIsolatedEdge","computeDisjointIM","labelIsolatedNodes","labelNodeEdges","labelIntersectionNodes","labelIsolatedNode","isContainedInBoundary","isPointContainedInBoundary","isLineStringContainedInBoundary","isLineSegmentContainedInBoundary","applyTo","checkIntersectionWithLineStrings","checkIntersectionWithSegments","getIntersectionMatrix","relate","touches","within","coveredBy","relateWithCheck","crosses","Po","RelateOp","extractElements","combine","createList","reduceToGeometries","unionTree","extractByEnvelope","unionOptimized","unionActual","unionUsingEnvelopeIntersection","STRTREE_NODE_CAPACITY","binaryUnion","unionSafe","repeatedUnion","restrictToPolygons","bufferUnion","unionNoOpt","unionWithNull","bo","UnaryUnionOp","Oo","IsValidOp","ConsistentAreaTester","_o","BoundaryOp","IsSimpleOp","linemerge","overlay","valid","fixPolygonalTopology","changePM","reducePointwise","createFactory","createEditor","setRemoveCollapsedComponents","setChangePrecisionModel","setPointwise","Mo","GeometryPrecisionReducer","simplifySection","setEnsureValid","DPTransformer","getParent","addToResult","asLineString","getResultSize","getSegment","getParentCoordinates","getMinimumSize","asLinearRing","getSegments","getResultCoordinates","hasBadIntersection","hasBadOutputIntersection","hasBadInputIntersection","findFurthestPoint","isInLineSection","LineStringTransformer","LineStringMapBuilderFilter","Do","DouglasPeuckerSimplifier","TopologyPreservingSimplifier","splitAt","pointAlongReverse","getConstrainedLength","setMinimumLength","getSplitPoint","findSplitPoint","projectedSplitPoint","triArea","isInCircleDDNormalized","checkRobustInCircle","isInCircleNonRobust","isInCircleDDSlow","isInCircleCC","toPoint","isInCircleDDFast","triAreaDDFast","isInCircleNormalized","triAreaDDSlow","isInCircleRobust","circleCenter","bisector","dot","magn","getZ","isInCircle","interpolateZValue","rightOf","setZ","times","leftOf","classify","BEHIND","BEYOND","ORIGIN","DESTINATION","BETWEEN","circumRadiusRatio","getConstraint","setOnConstraint","isOnConstraint","setConstraint","equalsNonOriented","equalsOriented","toLineSegment","dNext","lPrev","rPrev","rot","oPrev","setOrig","lNext","invRot","setDest","rNext","isLive","getPrimary","dPrev","makeEdge","connect","insertSite","isVertexOfEdge","isOnEdge","insertSites","locateFromEdge","getTriangleVertices","visitTriangles","isFrameVertex","getVoronoiCellPolygon","setLocator","isFrameBorderEdge","getTriangleEdges","fetchTriangleToVisit","isFrameEdge","getTriangleCoordinates","getTriangles","getVertices","getPrimaryEdges","getVertexUniqueEdges","getVoronoiCellPolygons","getVoronoiDiagram","checkTriangleSize","TriangleCircumcentreVisitor","TriangleEdgesListVisitor","TriangleVertexListVisitor","TriangleCoordinatesVisitor","getEndZ","getStartZ","getStart","getEnd","getEndY","getStartX","getStartY","getEndX","isRepeated","getRight","setLeft","getCount","getLeft","increment","setRight","findBestMatchNode","insertExact","queryNode","queryEnvelope","toCoordinates","BestMatchVisitor","getInitialVertices","getKDT","enforceConstraints","addConstraintVertices","enforceGabriel","MAX_SPLIT_ITER","getVertexFactory","getPointArray","setConstraints","computeConvexHull","findNonGabrielPoint","getConstraintSegments","setSplitPointFinder","createVertex","removeAll","getSubdivision","computeBoundingBox","computeVertexEnvelope","setVertexFactory","formInitialDelaunay","toVertices","setTolerance","setSites","extractUniqueCoordinates","createSiteVertices","containsKey","createVertices","createConstraintSegments","getDiagram","clipGeometryCollection","setClipEnvelope","Ao","Vertex","Fo","ConformingDelaunayTriangulationBuilder","DelaunayTriangulationBuilder","VoronoiDiagramBuilder","quadedge","toText","Go","version","geomgraph","noding","operation","coordinates2","convexHull2D","monotoneHull","hull","targetPoint","nearestPoint","minDist","distanceToPoint","robustSum","robustScale","robustSubtract","NUM_EXPAND","EPSILON","ERRBOUND3","ERRBOUND4","cofactor","generateSum","expr","determinant","neg","posExpr","negExpr","funcName","orientation3Exact","orientation4Exact","CACHED","tol","adx","bdx","cdx","ady","bdy","cdy","adz","bdz","cdz","bdxcdy","cdxbdy","cdxady","adxcdy","adxbdy","bdxady","permanent","slowOrient","generateOrientationProc","procArgs","fixed-header","fixedHeader","headerWidth","localizeHeaders","localize","sortedBy","descending","sortBy","onScroll","highlight","rowIndex","columnIndex","format-string","formatString","colspan","headerData","SimpleTableSortingButtonvue_type_template_id_6c9a549e_scoped_true_lang_html_render","fixed-width","SimpleTableSortingButtonvue_type_template_id_6c9a549e_scoped_true_lang_html_staticRenderFns","sortIcons","string","index_es","amount","SimpleTableSortingButtonvue_type_script_lang_js_","FaIcon","vue_fontawesome","icons","table_SimpleTableSortingButtonvue_type_script_lang_js_","SimpleTableSortingButton","defaultSortingFunctions","localeCompare","date","datetime","defaultSortingIcons","SimpleTablevue_type_script_lang_js_","SimpleTableAutoCell","disableInternalSort","sortable","_settings$value","_settings$sortingFunc","sortingFunction","_settings$sortingIcon","sortingIcon","sortedData","toConsumableArray","_this$headerData$this","sortedEventArgs","updated","tableBody","clientWidth","table_SimpleTablevue_type_script_lang_js_","SimpleTable_component","plus","minus","dividedBy","angleTo","sinθ","cosθ","rotateAround","axis","theta","qp","geometryCollection","factors","miles","nauticalmiles","degrees","inches","yards","meters","metres","kilometers","kilometres","feet","distanceToDegrees","lineSegmentStart","lineSegmentEnd","excludeBoundary","ignoreEndVertices","prevTime","selectColor","createDebug","self","curr","coerce","formatter","logFn","names","skips","centers","controls","stepLength","delay","dz","cacheSteps","mindist","laststep","step","vector","speed","time","bezier","t2","t3","t1","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_InputClearButton_vue_vue_type_style_index_0_id_451fb25d_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_InputClearButton_vue_vue_type_style_index_0_id_451fb25d_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","simplifyJS","cleanCoords","highQuality","simplifyLine","simplifyPolygon","simpleRing","checkValidity","supportsArgumentsClass","supported","object","unsupported","propertyIsEnumerable","turfLine","turfPoint","bearingToAngle","convertDistance","distanceToSegment","mercator","distanceAP","euclideanDistance","azimuthAP","azimuthAB","angleA","azimuthBA","azimuthBP","angleB","mercatorPH","toWGS84","euclideanIntersection","distancePH","dab","squareD","wgs84","ringArea","p3","lowerIndex","middleIndex","upperIndex","coordsLength","rad","cellSide","centered","bboxIsMask","bboxMask","bboxHorizontalSide","bboxVerticalSide","convergence","falseEasting","falseNorthing","mgrsLatBands","n4","n5","n6","tanλ","τ","sinh","atanh","τʹ","ξʹ","ηʹ","asinh","α","ξ","cosh","η","pʹ","qʹ","γʹ","γʺ","γ","kʹ","kʺ","β","sinhηʹ","sinξʹ","cosξʹ","τi","σi","τiʹ","δτi","tanh","latLong","utmCoord","each","adder","Adder","temp","av","epsilon2","halfPi","quarterPi","tau","math_sign","acos","haversin","noop","streamGeometry","stream","streamGeometryType","streamObjectType","Sphere","sphere","streamLine","streamPolygon","polygonStart","polygonEnd","area_lambda00","phi00","area_lambda0","area_cosPhi0","area_sinPhi0","src_stream","areaRingSum","areaSum","areaStream","areaRingStart","areaRingEnd","areaRing","areaPointFirst","areaPoint","lambda","phi","dLambda","sdLambda","adLambda","cosPhi","sinPhi","src_area","cartesian_spherical","cartesian","cartesian_cartesian","spherical","cartesianDot","cartesianCross","cartesianAddInPlace","cartesianScale","cartesianNormalizeInPlace","bounds_lambda0","bounds_phi0","bounds_lambda1","bounds_phi1","bounds_lambda2","bounds_lambda00","bounds_phi00","bounds_p0","ranges","range","deltaSum","boundsStream","boundsPoint","boundsLineStart","boundsLineEnd","boundsRingPoint","boundsRingStart","boundsRingEnd","bounds_linePoint","normal","equatorial","inflection","phii","lambdai","antimeridian","bounds_angle","lambda0","lambda1","rangeCompare","rangeContains","W0","W1","centroid_X0","centroid_Y0","Z0","centroid_X1","centroid_Y1","Z1","X2","Y2","Z2","centroid_lambda00","centroid_phi00","centroid_x0","centroid_y0","z0","deltaMax","centroidStream","centroidPoint","centroidLineStart","centroidLineEnd","centroidRingStart","centroidRingEnd","centroidPointCartesian","centroidLinePointFirst","centroidLinePoint","centroidRingPointFirst","centroidRingPoint","cz","constant","compose","rotationIdentity","rotateRadians","deltaLambda","deltaPhi","deltaGamma","rotationLambda","rotationPhiGamma","forwardRotationLambda","rotation","cosDeltaPhi","sinDeltaPhi","cosDeltaGamma","sinDeltaGamma","src_rotation","forward","circleStream","cosRadius","sinRadius","circleRadius","src_circle","circle","rejoin","pointEqual","Intersection","other","entry","compareIntersection","startInside","subject","clip","rejoin_link","current","isSubject","polygonContains_sum","polygonContains","winding","point0","phi0","sinPhi0","cosPhi0","sinPhi1","cosPhi1","phi1","absDelta","phiArc","ascending","ascendingComparator","ascendingBisect","array_array","src_range","arrays","src_clip","pointVisible","clipLine","sink","ringBuffer","ringSink","polygonStarted","pointRing","clip_compareIntersection","pointLine","clean","ringSegments","validSegment","clip_antimeridian","clipAntimeridianLine","clipAntimeridianInterpolate","sign0","sign1","clipAntimeridianIntersect","sinLambda0Lambda1","clip_circle","smallRadius","notHemisphere","visible","c0","v00","two","n1","n2n2","n1n2","n1xn2","polar","meridian","clip_line","clipMax","clipMin","clipRectangle","comparePoint","ca","cb","x__","y__","v__","x_","y_","v_","activeStream","bufferStream","clipStream","polygonInside","a0","b0","cleanInside","linePoint","length_lambda0","length_sinPhi0","length_cosPhi0","clip_extent","cache","cacheStream","extent","lengthSum","lengthStream","lengthLineStart","lengthPointFirst","lengthLineEnd","lengthPoint","cosDelta","sinDelta","src_length","distance_coordinates","distance_object","containsObjectType","containsGeometry","containsGeometryType","containsLine","containsPolygon","ob","ringRadians","pointRadians","graticuleX","graticuleY","graticule_graticule","X1","X0","Y1","Y0","DX","DY","graticule","extentMajor","extentMinor","stepMajor","stepMinor","graticule10","area_x00","area_y00","area_x0","area_y0","src_interpolate","cy0","sy0","cy1","sy1","kx0","ky0","kx1","ky1","src_identity","area_areaSum","area_areaRingSum","area_areaStream","area_areaRingStart","area_areaRingEnd","area_areaPointFirst","area_areaPoint","path_area","bounds_x0","bounds_y0","bounds_x1","bounds_y1","bounds_boundsStream","bounds_boundsPoint","centroid_x00","centroid_y00","path_centroid_x0","path_centroid_y0","path_bounds","path_centroid_X0","path_centroid_Y0","centroid_Z0","path_centroid_X1","path_centroid_Y1","centroid_Z1","centroid_X2","centroid_Y2","centroid_Z2","centroid_centroidStream","centroid_centroidPoint","centroid_centroidLineStart","centroid_centroidLineEnd","centroid_centroidRingStart","centroid_centroidRingEnd","centroidPointFirstLine","centroidPointLine","centroidPointFirstRing","centroidPointRing","path_centroid","PathContext","_radius","pointRadius","_line","_point","closePath","moveTo","lineTo","lengthRing","measure_x00","measure_y00","measure_x0","measure_y0","measure_lengthSum","measure_lengthStream","measure_lengthPointFirst","measure_lengthPoint","measure","PathString","_string","string_circle","_circle","src_path","projectionStream","contextStream","src_transform","transformer","TransformStream","fit","fitBounds","clipExtent","fitExtent","fitSize","fitWidth","fitHeight","height","maxDepth","cosMinDistance","resample","delta2","resample_resample","resampleNone","resampleLineTo","phi2","lambda2","dx2","dy2","lambda00","x00","y00","a00","b00","c00","resampleStream","ringPoint","transformRadians","transformRotate","scaleTranslate","scaleTranslateRotate","alpha","cosAlpha","sinAlpha","projection_projection","projectionMutator","projectAt","projectResample","projectTransform","projectRotateTransform","preclip","postclip","recenter","clipAngle","conicProjection","parallels","cylindricalEqualAreaRaw","conicEqualAreaRaw","r0","r0y","conicEqualArea","albers","multiplex","streams","projection_albersUsa","lower48Point","alaskaPoint","hawaiiPoint","lower48","alaska","hawaii","pointStream","albersUsa","azimuthalRaw","azimuthalInvert","sc","azimuthalEqualAreaRaw","cxcy","azimuthalEqualArea","azimuthalEquidistantRaw","azimuthalEquidistant","mercatorRaw","mercatorProjection","reclip","tany","conicConformalRaw","fy","conicConformal","equirectangularRaw","equirectangular","conicEquidistantRaw","gy","nx","conicEquidistant","A1","A2","A3","A4","equalEarthRaw","l6","fpy","equalEarth","gnomonicRaw","gnomonic","identity_scaleTranslate","projection_identity","sx","sy","reflectX","reflectY","naturalEarth1Raw","phi4","naturalEarth1","orthographicRaw","orthographic","stereographicRaw","stereographic","transverseMercatorRaw","transverseMercator","scalarScalar","linearExpansionSum","nf","eptr","fptr","ea","fa","_bv","_av","_br","_ar","q0","INT_BITS","countTrailingZeros","INT_MAX","INT_MIN","isPow2","log2","nextPow2","prevPow2","REVERSE_TABLE","tab","interleave2","deinterleave2","interleave3","deinterleave3","lineIntersects","line1StartX","line1StartY","line1EndX","line1EndY","line2StartX","line2StartY","line2EndX","line2EndY","denominator","numerator1","numerator2","onLine1","onLine2","featureIn","line1","line2","inProperty","outProperty","property","potentialPoints","removeEmptyPolygon","polygon1","polygon2","differenced","start0","end0","start1","end1","equalArrays","denom","x4","y4","array1","array2","defaults","useSpatialIndex","reportVertexOnVertex","reportVertexOnEdge","filterFn","options0","seen","allEdgesAsRbushTreeItems","ring0","edge0","rbushTreeItem","bboxOverlaps","bboxIsect","ring1","edge1","ifIsectAddToOutput","isBoundaryCase","frac","isOutside","isect","frac0","frac1","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FilterSelector_vue_vue_type_style_index_0_id_cd193c48_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FilterSelector_vue_vue_type_style_index_0_id_cd193c48_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","final","calculateFinalBearing","bear","buildMask","maskPolygon","polygonOuters","polygonInners","separatePolygons","outers","inners","featureOuter","featureInner","inner","createMask","world","unionPolygons","createIndex","removed","filterByIndex","separated","masked","commit","toVector","toLatLonS","greatCircle","θ","eʹ","nʹ","δ","bearingTo","midpointTo","intermediatePointTo","fraction","δi","sinδi","cosδi","int","intermediatePointOnChordTo","deSinθ","dnCosθ","path1start","path1brngEnd","path2start","path2brngEnd","path1def","path2def","i1","dir1","dir2","crossTrackDistanceTo","pathStart","pathBrngEnd","gc","alongTrackDistanceTo","pat","nearestPointOnSegment","n0","δ10","δ12","δ20","δ21","extent1","extent2","isSameHemisphere","enclosedBy","nVertices","vectorToVertex","Σθ","enclosed","areaOf","Σα","meanOf","gj","mem","measureDistance","getRandomSubarray","shuffled","num","outFC","bandwidth","computeBandGrid","BandGrid2Areas","BandGrid2AreaPaths","Node0","Node1","Node2","Node3","isoBandNextXTL","isoBandNextYTL","isoBandNextOTL","isoBandNextXTR","isoBandNextYTR","isoBandNextOTR","isoBandNextXRT","isoBandNextYRT","isoBandNextORT","isoBandNextXRB","isoBandNextYRB","isoBandNextORB","isoBandNextXBL","isoBandNextYBL","isoBandNextOBL","isoBandNextXBR","isoBandNextYBR","isoBandNextOBR","isoBandNextXLT","isoBandNextYLT","isoBandNextOLT","isoBandNextXLB","isoBandNextYLB","isoBandNextOLB","p00","p01","p02","p03","p04","p05","p06","p07","p08","p09","p10","p11","p12","p13","p14","p15","p16","p17","p18","p19","p20","p21","p22","p23","p24","p25","p26","p27","p28","p29","p30","p31","p32","p33","p34","p35","p36","p37","p38","p39","isoBandEdgeRT","isoBandEdgeRB","isoBandEdgeBR","isoBandEdgeBL","isoBandEdgeLB","isoBandEdgeLT","isoBandEdgeTL","isoBandEdgeTR","polygon_table","myArray","BandGrid","cval_real","areas","currentPolygon","getStartXY","getExitXY","missing","traceOutOfGridPath","d_x","d_y","d_o","edgeIdx","id_x","area_idx","aa","aaa","flattenCoords","ToggleButtonvue_type_script_lang_js_","toggleValue","button","components_ToggleButtonvue_type_script_lang_js_","lineSegment","numeA","numeB","uA","uB","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SimpleTableSortingButton_vue_vue_type_style_index_0_id_6c9a549e_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SimpleTableSortingButton_vue_vue_type_style_index_0_id_6c9a549e_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","Coord","view","antipode","anti_lat","anti_lon","move_to","Arc","multiline","wkt","wkt_string","collect","GreatCircle","npoints","first_pass","pair","bHasBigDiff","dfMaxSmallDiffLong","dfDateLineOffset","dfLeftBorderX","dfRightBorderX","dfDiffSpace","dfPrevX","dfX","dfDiffLong","poMulti","poNewLS","dfX0","dfX1","dfY1","dfX2","dfY2","tmpX","tmpY","dfRatio","dfY","poNewLS0","j0","cultivationColumns","cultivationTypeTranslations","cropUsageId","mixture","mixtures","underseedMixtureId","ref_value","FrsCultivationOverviewTablevue_type_script_lang_js_","SimpleTable","catchCropMixtures","selection","orgUnit","dateTimeRange","main","SR_FieldRecordSystem","MainCrop","eco","EcologicalPriorityArea","catch","CatchCrop","base_FrsCultivationOverviewTablevue_type_script_lang_js_","feat","isNumber","centimeters","centimetres","areaFactors","millimeter","acres","multiplier","originalUnit","finalUnit","convertedDistance","convertArea","startFactor","finalFactor","convertAngleTo360","alfa","beta","bearing1","bearing2","angle1","angle2","arcStartDegree","arcEndDegree","outField","SPLITTER","abig","ahi","alo","bbig","bhi","blo","err1","err2","err3","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FrsCultivationOverviewTable_vue_vue_type_style_index_0_id_21f1e008_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_FrsCultivationOverviewTable_vue_vue_type_style_index_0_id_21f1e008_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","parseDMS","dmsStr","deg","dms","separator","toDMS","toBrng","compassPoint","cardinals","cardinal","coordId","mergeLineStrings","e1","mergeViableLineStrings","lineStrings","accum","lineStringToPolygon","autoComplete","orderCoords","autoCompleteCoords","multiCoords","largestArea","calculateArea","fromGeoJson","shells","_turf_helpers__WEBPACK_IMPORTED_MODULE_0__","_turf_difference__WEBPACK_IMPORTED_MODULE_7__","_turf_simplify__WEBPACK_IMPORTED_MODULE_11__","_turf_buffer__WEBPACK_IMPORTED_MODULE_19__","_turf_center__WEBPACK_IMPORTED_MODULE_20__","_turf_bbox__WEBPACK_IMPORTED_MODULE_26__","_turf_intersect__WEBPACK_IMPORTED_MODULE_30__","_turf_union__WEBPACK_IMPORTED_MODULE_35__","_turf_area__WEBPACK_IMPORTED_MODULE_40__","_turf_boolean_equal__WEBPACK_IMPORTED_MODULE_81__","lineArc","sliceCoords","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SimpleTable_vue_vue_type_style_index_0_id_2728a880_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SimpleTable_vue_vue_type_style_index_0_id_2728a880_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","addOuterEdge","addInnerEdge","removeOuterEdge","removeInnerEdge","createContourLines","contours","lowerBand","upperBand","isobandsCoords","nestedRings","orderByArea","groupedRings","groupNestedRings","rescaleContours","contour","lineRingSet","lineRing","ringsCoords","ringsWithArea","orderedByArea","orderedLinearRings","lrList","lrCoordinates","grouped","groupedLinearRingsCoords","allGrouped","outerMostPoly","lrPoly","testPolygon","targetPolygon","commonProperties","isobandProperties","multipolygons","contourProperties","multiP","monotoneConvexHull2D","lower","upper","nl","convexHullnD","ich","aff","permute","front","invPermute","ah","booleanPointOnLine","concatSegment","overlapSegment","doesOverlaps","coordsSegment","coordsMatch","feedback-classes","feedbackClasses","components_VueSelectizevue_type_script_lang_js_","VueSelectizevue_type_script_lang_js_","_obj","partially-selected","panelClass","titleTranslate","subtitle","subtitleTranslate","ListCardvue_type_script_lang_js_","locked","showAvatar","showDetails","card_ListCardvue_type_script_lang_js_","fastTwoSum","nextPoint","secondToLast","startX","startY","endX","endY","newCoords","polyPoints","Δφ","Bx","By","φ3","λ3","sinφ1","cosφ1","sinλ1","cosλ1","sinφ2","cosφ2","sinλ2","cosλ2","sinδ","cosδ","brng1","brng2","θ13","θ23","θa","θb","θ12","θ21","α3","δ13","Δλ13","pathEnd","δxt","δat","maxLatitude","φMax","crossingParallels","latitude","λm","Δλi","λi1","λi2","Δψ","rhumbBearingTo","rhumbMidpointTo","f1","f2","f3","isPoleEnclosedBy","ΣΔ","prevBrng","initBrng","finalBrng","bear360","coordsStart","coordsEnd","bear180","IxWmsLayervue_type_script_lang_js_","inject","clipFeatures","recreate","getLayers","openlayers_layers","olFeatures","readFeature","turf_module","combined","ol_extent","getExtent","setExtent","_url","getSource","setUrl","_layers","updateParams","LAYERS","getMap","map_IxWmsLayervue_type_script_lang_js_","splitLineWithPoints","splitter","closestLine","findClosestFeature","splitLineWithPoint","pointsEquals","closestSegment","lastCoords","previous","splitterCoords","closestFeature","lineType","splitterType","truncatedSplitter","dx1","dy1","envX1","envY1","envX2","envY2","placement","input-group","addon","usePercent","inputGroup","faded","has-input","inputText","readonly","aria-describedby","displayValue","updateText","srState","translateUnit","resources","SR_ErrorMessages","NumericInputvue_type_script_lang_js_","RuleMixin","InputMixin","make_resource_mixin","ChangeDetectionMixin","hideDescription","clearButton","percent","percentNotNormalized","convertedValue","truncatedValue","onInputDebounced","parts","overrideInputText","formattedValue","newValue","fractionalDigits","willBeTruncated","truncated","rules","internalHighPriority","internalLowPriority","warning","Truncate","OnlyIntegers","OnlyFloatingNumbers","prioritizedMessages","convertedInput","setTimeout","activeElement","forms_NumericInputvue_type_script_lang_js_","roots","makeSet","xd","yd","identity","bboxPoint","bboxGeometry","feature_feature","feature_object","stitch","stitchedArcs","fragmentByStart","fragmentByEnd","fragments","emptyIndex","flush","fg","gf","mesh","meshArcs","extractArcs","geomsByArc","extract0","extract1","extract2","extract3","planarRingArea","mergeArcs","polygonsByArc","neighbors","bisect","src_neighbors","indexesByArc","geometryType","ij","ik","untransform","quantize","box","quantizeArc","generator","Searchvue_type_script_lang_js_","SearchBar","fuse","fuse_default","_result","search_Searchvue_type_script_lang_js_","closestPt","sectionLength","heightDistance","perpendicularPt1","perpendicularPt2","intersectPt","anyMatch","foundInsidePoint","oneInside","cosines","sines","hexagon","hexTriangles","cellDiameter","centerY","centerX","hex_width","hex_height","box_width","box_height","x_interval","y_interval","x_span","x_count","x_adjust","y_count","y_adjust","hasOffsetY","isOdd","center_x","center_y","zTranslation","doMultiPointAndLineStringCross","foundIntPoint","foundExtPoint","pointLength","incEndVertices","doLineStringsCross","doLineStringAndPolygonCross","isPointInPoly","doesMultiPointCrossPoly","incEnd","_getClosest","getDiff","closest","comparedItem","comparedItemIndex","thisDiff","lowerNumber","custom","comparator","SimpleTableBooleanvue_type_template_id_376a24ea_lang_html_functional_true_render","SimpleTableBooleanvue_type_script_lang_js_","table_SimpleTableBooleanvue_type_script_lang_js_","SimpleTableBoolean","SimpleTableStringArray","functional","_context$props","cloneFeature","cloned","cloneProperties","cloneGeometry","cloneFeatureCollection","deepSlice","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SatImageCard_vue_vue_type_style_index_0_id_99411b72_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_8_oneOf_1_0_node_modules_css_loader_index_js_ref_8_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_8_oneOf_1_2_node_modules_sass_loader_lib_loader_js_ref_8_oneOf_1_3_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_SatImageCard_vue_vue_type_style_index_0_id_99411b72_lang_scss_scoped_true___WEBPACK_IMPORTED_MODULE_0___default","convex","centerOfMass","pj","translation","sArea","neutralizedPoints","areaFactor","createSegments","__WEBPACK_AMD_DEFINE_FACTORY__","isects","debugAll","numRings","isUnique","numvertices","selfIsectsData","numSelfIsect","outputFeatureArray","windingOfRing","determineParents","setNetWinding","pseudoVtxListByRingAndEdge","isectList","PseudoVtx","modulo","Isect","numIsect","param","allIsectsAsIsectRbushTreeItem","isectRbushTree","coordToFind","IsectRbushTreeItemFound","nxtIsectAlongEdgeIn","nxtIsectAlongRingAndEdge2","ringAndEdge1","ringAndEdgeIn","nxtIsectAlongRingAndEdge1","leftIsect","isectAfterLeftIsect","isectBeforeLeftIsect","windingAtIsect","popped","startIsect","currentOutputRingParent","currentOutputRingWinding","currentOutputRing","currentOutputRingCoords","currentIsect","ringAndEdge1Walkable","walkingRingAndEdge","nxtIsect","ringAndEdge2","nxtIsectInQueue","ringAndEdge2Walkable","pushing","netWinding","featuresWithoutParent","parentArea","setNetWindingOfChildren","ParentNetWinding","ringAndEdgeOut","righthanded","leftVtx","loaded","back","backToDashboard","FrsModuleRootvue_type_script_lang_js_","ModuleRootMixin","setRightView","base_FrsModuleRootvue_type_script_lang_js_","pivot","initialAngle","finalAngle","lineOffset","offsetDegrees","finalCoords","processSegment","seg2Coords","out1x","out2x","out1y","out2y","modules","installedModules","moduleId","getter","__esModule","bitapRegexSearch","bitapSearch","patternAlphabet","Bitap","pattern","_ref","_ref$location","_ref$distance","_ref$threshold","_ref$maxPatternLength","maxPatternLength","_ref$isCaseSensitive","isCaseSensitive","_ref$tokenSeparator","tokenSeparator","_ref$findAllMatches","findAllMatches","_ref$minMatchCharLeng","minMatchCharLength","isMatch","score","matchedIndices","_options","_options2","deepValue","dotIndex","firstSegment","remaining","matchmask","SPECIAL_CHARS_REGEX","matchesLen","_ref$errors","errors","_ref$currentLocation","currentLocation","_ref$expectedLocation","expectedLocation","accuracy","proximity","bitapScore","textLen","currentThreshold","bestLocation","patternLen","matchMask","_score","lastBitArr","finalScore","binMax","binMin","binMid","_score3","bitArr","charMatch","_score2","Fuse","_ref$caseSensitive","caseSensitive","_ref$id","_ref$keys","_ref$shouldSort","shouldSort","_ref$getFn","getFn","_ref$sortFn","sortFn","_ref$tokenize","tokenize","_ref$matchAllTokens","matchAllTokens","_ref$includeMatches","includeMatches","_ref$includeScore","includeScore","_ref$verbose","setCollection","_log","_prepareSearchers2","_prepareSearchers","tokenSearchers","fullSearcher","_search2","_search","weights","_computeScore","_sort","_format","tokens","resultMap","_analyze","record","_len","keysLen","_ref2","_ref3","_ref2$arrayIndex","arrayIndex","_ref3$tokenSearchers","_ref3$fullSearcher","_ref3$resultMap","_ref3$results","exists","averageScore","numTextMatches","mainSearchResult","words","scores","tokenSearcher","hasMatchInText","word","tokenSearchResult","scoresLen","_i2","checkTextMatches","existingResult","_i3","scoreLen","currScore","bestScore","nScore","finalOutput","transformers","indices","_len2","_console"],"mappings":"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","file":"js/chunk-34a5d69e.82f1de4e.js","sourcesContent":["\"use strict\"\n\n//High level idea:\n// 1. Use Clarkson's incremental construction to find convex hull\n// 2. Point location in triangulation by jump and walk\n\nmodule.exports = incrementalConvexHull\n\nvar orient = require(\"robust-orientation\")\nvar compareCell = require(\"simplicial-complex\").compareCells\n\nfunction compareInt(a, b) {\n return a - b\n}\n\nfunction Simplex(vertices, adjacent, boundary) {\n this.vertices = vertices\n this.adjacent = adjacent\n this.boundary = boundary\n this.lastVisited = -1\n}\n\nSimplex.prototype.flip = function() {\n var t = this.vertices[0]\n this.vertices[0] = this.vertices[1]\n this.vertices[1] = t\n var u = this.adjacent[0]\n this.adjacent[0] = this.adjacent[1]\n this.adjacent[1] = u\n}\n\nfunction GlueFacet(vertices, cell, index) {\n this.vertices = vertices\n this.cell = cell\n this.index = index\n}\n\nfunction compareGlue(a, b) {\n return compareCell(a.vertices, b.vertices)\n}\n\nfunction bakeOrient(d) {\n var code = [\"function orient(){var tuple=this.tuple;return test(\"]\n for(var i=0; i<=d; ++i) {\n if(i > 0) {\n code.push(\",\")\n }\n code.push(\"tuple[\", i, \"]\")\n }\n code.push(\")}return orient\")\n var proc = new Function(\"test\", code.join(\"\"))\n var test = orient[d+1]\n if(!test) {\n test = orient\n }\n return proc(test)\n}\n\nvar BAKED = []\n\nfunction Triangulation(dimension, vertices, simplices) {\n this.dimension = dimension\n this.vertices = vertices\n this.simplices = simplices\n this.interior = simplices.filter(function(c) {\n return !c.boundary\n })\n\n this.tuple = new Array(dimension+1)\n for(var i=0; i<=dimension; ++i) {\n this.tuple[i] = this.vertices[i]\n }\n\n var o = BAKED[dimension]\n if(!o) {\n o = BAKED[dimension] = bakeOrient(dimension)\n }\n this.orient = o\n}\n\nvar proto = Triangulation.prototype\n\n//Degenerate situation where we are on boundary, but coplanar to face\nproto.handleBoundaryDegeneracy = function(cell, point) {\n var d = this.dimension\n var n = this.vertices.length - 1\n var tuple = this.tuple\n var verts = this.vertices\n\n //Dumb solution: Just do dfs from boundary cell until we find any peak, or terminate\n var toVisit = [ cell ]\n cell.lastVisited = -n\n while(toVisit.length > 0) {\n cell = toVisit.pop()\n var cellVerts = cell.vertices\n var cellAdj = cell.adjacent\n for(var i=0; i<=d; ++i) {\n var neighbor = cellAdj[i]\n if(!neighbor.boundary || neighbor.lastVisited <= -n) {\n continue\n }\n var nv = neighbor.vertices\n for(var j=0; j<=d; ++j) {\n var vv = nv[j]\n if(vv < 0) {\n tuple[j] = point\n } else {\n tuple[j] = verts[vv]\n }\n }\n var o = this.orient()\n if(o > 0) {\n return neighbor\n }\n neighbor.lastVisited = -n\n if(o === 0) {\n toVisit.push(neighbor)\n }\n }\n }\n return null\n}\n\nproto.walk = function(point, random) {\n //Alias local properties\n var n = this.vertices.length - 1\n var d = this.dimension\n var verts = this.vertices\n var tuple = this.tuple\n\n //Compute initial jump cell\n var initIndex = random ? (this.interior.length * Math.random())|0 : (this.interior.length-1)\n var cell = this.interior[ initIndex ]\n\n //Start walking\nouterLoop:\n while(!cell.boundary) {\n var cellVerts = cell.vertices\n var cellAdj = cell.adjacent\n\n for(var i=0; i<=d; ++i) {\n tuple[i] = verts[cellVerts[i]]\n }\n cell.lastVisited = n\n\n //Find farthest adjacent cell\n for(var i=0; i<=d; ++i) {\n var neighbor = cellAdj[i]\n if(neighbor.lastVisited >= n) {\n continue\n }\n var prev = tuple[i]\n tuple[i] = point\n var o = this.orient()\n tuple[i] = prev\n if(o < 0) {\n cell = neighbor\n continue outerLoop\n } else {\n if(!neighbor.boundary) {\n neighbor.lastVisited = n\n } else {\n neighbor.lastVisited = -n\n }\n }\n }\n return\n }\n\n return cell\n}\n\nproto.addPeaks = function(point, cell) {\n var n = this.vertices.length - 1\n var d = this.dimension\n var verts = this.vertices\n var tuple = this.tuple\n var interior = this.interior\n var simplices = this.simplices\n\n //Walking finished at boundary, time to add peaks\n var tovisit = [ cell ]\n\n //Stretch initial boundary cell into a peak\n cell.lastVisited = n\n cell.vertices[cell.vertices.indexOf(-1)] = n\n cell.boundary = false\n interior.push(cell)\n\n //Record a list of all new boundaries created by added peaks so we can glue them together when we are all done\n var glueFacets = []\n\n //Do a traversal of the boundary walking outward from starting peak\n while(tovisit.length > 0) {\n //Pop off peak and walk over adjacent cells\n var cell = tovisit.pop()\n var cellVerts = cell.vertices\n var cellAdj = cell.adjacent\n var indexOfN = cellVerts.indexOf(n)\n if(indexOfN < 0) {\n continue\n }\n\n for(var i=0; i<=d; ++i) {\n if(i === indexOfN) {\n continue\n }\n\n //For each boundary neighbor of the cell\n var neighbor = cellAdj[i]\n if(!neighbor.boundary || neighbor.lastVisited >= n) {\n continue\n }\n\n var nv = neighbor.vertices\n\n //Test if neighbor is a peak\n if(neighbor.lastVisited !== -n) { \n //Compute orientation of p relative to each boundary peak\n var indexOfNeg1 = 0\n for(var j=0; j<=d; ++j) {\n if(nv[j] < 0) {\n indexOfNeg1 = j\n tuple[j] = point\n } else {\n tuple[j] = verts[nv[j]]\n }\n }\n var o = this.orient()\n\n //Test if neighbor cell is also a peak\n if(o > 0) {\n nv[indexOfNeg1] = n\n neighbor.boundary = false\n interior.push(neighbor)\n tovisit.push(neighbor)\n neighbor.lastVisited = n\n continue\n } else {\n neighbor.lastVisited = -n\n }\n }\n\n var na = neighbor.adjacent\n\n //Otherwise, replace neighbor with new face\n var vverts = cellVerts.slice()\n var vadj = cellAdj.slice()\n var ncell = new Simplex(vverts, vadj, true)\n simplices.push(ncell)\n\n //Connect to neighbor\n var opposite = na.indexOf(cell)\n if(opposite < 0) {\n continue\n }\n na[opposite] = ncell\n vadj[indexOfN] = neighbor\n\n //Connect to cell\n vverts[i] = -1\n vadj[i] = cell\n cellAdj[i] = ncell\n\n //Flip facet\n ncell.flip()\n\n //Add to glue list\n for(var j=0; j<=d; ++j) {\n var uu = vverts[j]\n if(uu < 0 || uu === n) {\n continue\n }\n var nface = new Array(d-1)\n var nptr = 0\n for(var k=0; k<=d; ++k) {\n var vv = vverts[k]\n if(vv < 0 || k === j) {\n continue\n }\n nface[nptr++] = vv\n }\n glueFacets.push(new GlueFacet(nface, ncell, j))\n }\n }\n }\n\n //Glue boundary facets together\n glueFacets.sort(compareGlue)\n\n for(var i=0; i+1= 0) {\n bcell[ptr++] = cv[j]\n } else {\n parity = j&1\n }\n }\n if(parity === (d&1)) {\n var t = bcell[0]\n bcell[0] = bcell[1]\n bcell[1] = t\n }\n boundary.push(bcell)\n }\n }\n return boundary\n}\n\nfunction incrementalConvexHull(points, randomSearch) {\n var n = points.length\n if(n === 0) {\n throw new Error(\"Must have at least d+1 points\")\n }\n var d = points[0].length\n if(n <= d) {\n throw new Error(\"Must input at least d+1 points\")\n }\n\n //FIXME: This could be degenerate, but need to select d+1 non-coplanar points to bootstrap process\n var initialSimplex = points.slice(0, d+1)\n\n //Make sure initial simplex is positively oriented\n var o = orient.apply(void 0, initialSimplex)\n if(o === 0) {\n throw new Error(\"Input not in general position\")\n }\n var initialCoords = new Array(d+1)\n for(var i=0; i<=d; ++i) {\n initialCoords[i] = i\n }\n if(o < 0) {\n initialCoords[0] = 1\n initialCoords[1] = 0\n }\n\n //Create initial topological index, glue pointers together (kind of messy)\n var initialCell = new Simplex(initialCoords, new Array(d+1), false)\n var boundary = initialCell.adjacent\n var list = new Array(d+2)\n for(var i=0; i<=d; ++i) {\n var verts = initialCoords.slice()\n for(var j=0; j<=d; ++j) {\n if(j === i) {\n verts[j] = -1\n }\n }\n var t = verts[0]\n verts[0] = verts[1]\n verts[1] = t\n var cell = new Simplex(verts, new Array(d+1), true)\n boundary[i] = cell\n list[i] = cell\n }\n list[d+1] = initialCell\n for(var i=0; i<=d; ++i) {\n var verts = boundary[i].vertices\n var adj = boundary[i].adjacent\n for(var j=0; j<=d; ++j) {\n var v = verts[j]\n if(v < 0) {\n adj[j] = initialCell\n continue\n }\n for(var k=0; k<=d; ++k) {\n if(boundary[k].vertices.indexOf(v) < 0) {\n adj[j] = boundary[k]\n }\n }\n }\n }\n\n //Initialize triangles\n var triangles = new Triangulation(d, initialSimplex, list)\n\n //Insert remaining points\n var useRandom = !!randomSearch\n for(var i=d+1; i|Geometry|Feature} obj Object\n * @returns {Array} coordinates\n * @example\n * var pt = turf.point([10, 10]);\n *\n * var coord = turf.getCoord(pt);\n * //= [10, 10]\n */\nfunction getCoord(obj) {\n if (!obj) throw new Error('obj is required');\n\n var coordinates = getCoords(obj);\n\n // getCoord() must contain at least two numbers (Point)\n if (coordinates.length > 1 &&\n typeof coordinates[0] === 'number' &&\n typeof coordinates[1] === 'number') {\n return coordinates;\n } else {\n throw new Error('Coordinate is not a valid Point');\n }\n}\n\n/**\n * Unwrap coordinates from a Feature, Geometry Object or an Array of numbers\n *\n * @name getCoords\n * @param {Array|Geometry|Feature} obj Object\n * @returns {Array} coordinates\n * @example\n * var poly = turf.polygon([[[119.32, -8.7], [119.55, -8.69], [119.51, -8.54], [119.32, -8.7]]]);\n *\n * var coord = turf.getCoords(poly);\n * //= [[[119.32, -8.7], [119.55, -8.69], [119.51, -8.54], [119.32, -8.7]]]\n */\nfunction getCoords(obj) {\n if (!obj) throw new Error('obj is required');\n var coordinates;\n\n // Array of numbers\n if (obj.length) {\n coordinates = obj;\n\n // Geometry Object\n } else if (obj.coordinates) {\n coordinates = obj.coordinates;\n\n // Feature\n } else if (obj.geometry && obj.geometry.coordinates) {\n coordinates = obj.geometry.coordinates;\n }\n // Checks if coordinates contains a number\n if (coordinates) {\n containsNumber(coordinates);\n return coordinates;\n }\n throw new Error('No valid coordinates');\n}\n\n/**\n * Checks if coordinates contains a number\n *\n * @name containsNumber\n * @param {Array} coordinates GeoJSON Coordinates\n * @returns {boolean} true if Array contains a number\n */\nfunction containsNumber(coordinates) {\n if (coordinates.length > 1 &&\n typeof coordinates[0] === 'number' &&\n typeof coordinates[1] === 'number') {\n return true;\n }\n\n if (Array.isArray(coordinates[0]) && coordinates[0].length) {\n return containsNumber(coordinates[0]);\n }\n throw new Error('coordinates must only contain numbers');\n}\n\n/**\n * Enforce expectations about types of GeoJSON objects for Turf.\n *\n * @name geojsonType\n * @param {GeoJSON} value any GeoJSON object\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction geojsonType(value, type, name) {\n if (!type || !name) throw new Error('type and name required');\n\n if (!value || value.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + value.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link Feature} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @name featureOf\n * @param {Feature} feature a feature with an expected geometry type\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} error if value is not the expected type.\n */\nfunction featureOf(feature, type, name) {\n if (!feature) throw new Error('No feature passed');\n if (!name) throw new Error('.featureOf() requires a name');\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link FeatureCollection} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @name collectionOf\n * @param {FeatureCollection} featureCollection a FeatureCollection for which features will be judged\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction collectionOf(featureCollection, type, name) {\n if (!featureCollection) throw new Error('No featureCollection passed');\n if (!name) throw new Error('.collectionOf() requires a name');\n if (!featureCollection || featureCollection.type !== 'FeatureCollection') {\n throw new Error('Invalid input to ' + name + ', FeatureCollection required');\n }\n for (var i = 0; i < featureCollection.features.length; i++) {\n var feature = featureCollection.features[i];\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n }\n}\n\n/**\n * Get Geometry from Feature or Geometry Object\n *\n * @param {Feature|Geometry} geojson GeoJSON Feature or Geometry Object\n * @returns {Geometry|null} GeoJSON Geometry Object\n * @throws {Error} if geojson is not a Feature or Geometry Object\n * @example\n * var point = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 40]\n * }\n * }\n * var geom = turf.getGeom(point)\n * //={\"type\": \"Point\", \"coordinates\": [110, 40]}\n */\nfunction getGeom(geojson) {\n if (!geojson) throw new Error('geojson is required');\n if (geojson.geometry !== undefined) return geojson.geometry;\n if (geojson.coordinates || geojson.geometries) return geojson;\n throw new Error('geojson must be a valid Feature or Geometry Object');\n}\n\n/**\n * Get Geometry Type from Feature or Geometry Object\n *\n * @param {Feature|Geometry} geojson GeoJSON Feature or Geometry Object\n * @returns {string} GeoJSON Geometry Type\n * @throws {Error} if geojson is not a Feature or Geometry Object\n * @example\n * var point = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 40]\n * }\n * }\n * var geom = turf.getGeomType(point)\n * //=\"Point\"\n */\nfunction getGeomType(geojson) {\n if (!geojson) throw new Error('geojson is required');\n var geom = getGeom(geojson);\n if (geom) return geom.type;\n}\n\nmodule.exports = {\n geojsonType: geojsonType,\n collectionOf: collectionOf,\n featureOf: featureOf,\n getCoord: getCoord,\n getCoords: getCoords,\n containsNumber: containsNumber,\n getGeom: getGeom,\n getGeomType: getGeomType\n};\n","var flattenEach = require('@turf/meta').flattenEach;\nvar featureCollection = require('@turf/helpers').featureCollection;\n\n/**\n * Flattens any {@link GeoJSON} to a {@link FeatureCollection} inspired by [geojson-flatten](https://github.com/tmcw/geojson-flatten).\n *\n * @name flatten\n * @param {FeatureCollection|Geometry|Feature} geojson any valid GeoJSON Object\n * @returns {FeatureCollection} all Multi-Geometries are flattened into single Features\n * @example\n * var multiGeometry = turf.multiPolygon([\n * [[[102.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0]]],\n * [[[100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0]],\n * [[100.2, 0.2], [100.8, 0.2], [100.8, 0.8], [100.2, 0.8], [100.2, 0.2]]]\n * ]);\n *\n * var flatten = turf.flatten(multiGeometry);\n *\n * //addToMap\n * var addToMap = [flatten]\n */\nmodule.exports = function (geojson) {\n if (!geojson) throw new Error('geojson is required');\n\n var results = [];\n flattenEach(geojson, function (feature) {\n results.push(feature);\n });\n return featureCollection(results);\n};\n","/**\n * Callback for coordEach\n *\n * @private\n * @callback coordEachCallback\n * @param {[number, number]} currentCoords The current coordinates being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentCoords, currentIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordEach(features, function (currentCoords, currentIndex) {\n * //=currentCoords\n * //=currentIndex\n * });\n */\nfunction coordEach(layer, callback, excludeWrapCoord) {\n var i, j, k, g, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n currentIndex = 0,\n isGeometryCollection,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n coords = geometry.coordinates;\n\n wrapShrink = (excludeWrapCoord &&\n (geometry.type === 'Polygon' || geometry.type === 'MultiPolygon')) ?\n 1 : 0;\n\n if (geometry.type === 'Point') {\n callback(coords, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'LineString' || geometry.type === 'MultiPoint') {\n for (j = 0; j < coords.length; j++) {\n callback(coords[j], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'Polygon' || geometry.type === 'MultiLineString') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n callback(coords[j][k], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'MultiPolygon') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length; k++)\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n callback(coords[j][k][l], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++)\n coordEach(geometry.geometries[j], callback, excludeWrapCoord);\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.coordEach = coordEach;\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {[number, number]} currentCoords The current coordinate being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoords, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordReduce(features, function (previousValue, currentCoords, currentIndex) {\n * //=previousValue\n * //=currentCoords\n * //=currentIndex\n * return currentCoords;\n * });\n */\nfunction coordReduce(layer, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(layer, function (currentCoords, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentCoords;\n } else {\n previousValue = callback(previousValue, currentCoords, currentIndex);\n }\n }, excludeWrapCoord);\n return previousValue;\n}\nmodule.exports.coordReduce = coordReduce;\n\n/**\n * Callback for propEach\n *\n * @private\n * @callback propEachCallback\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propEach(features, function (currentProperties, currentIndex) {\n * //=currentProperties\n * //=currentIndex\n * });\n */\nfunction propEach(layer, callback) {\n var i;\n switch (layer.type) {\n case 'FeatureCollection':\n for (i = 0; i < layer.features.length; i++) {\n callback(layer.features[i].properties, i);\n }\n break;\n case 'Feature':\n callback(layer.properties, 0);\n break;\n }\n}\nmodule.exports.propEach = propEach;\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propReduce(features, function (previousValue, currentProperties, currentIndex) {\n * //=previousValue\n * //=currentProperties\n * //=currentIndex\n * return currentProperties\n * });\n */\nfunction propReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n propEach(layer, function (currentProperties, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentProperties;\n } else {\n previousValue = callback(previousValue, currentProperties, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.propReduce = propReduce;\n\n/**\n * Callback for featureEach\n *\n * @private\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureEach(features, function (currentFeature, currentIndex) {\n * //=currentFeature\n * //=currentIndex\n * });\n */\nfunction featureEach(layer, callback) {\n if (layer.type === 'Feature') {\n callback(layer, 0);\n } else if (layer.type === 'FeatureCollection') {\n for (var i = 0; i < layer.features.length; i++) {\n callback(layer.features[i], i);\n }\n }\n}\nmodule.exports.featureEach = featureEach;\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureReduce(features, function (previousValue, currentFeature, currentIndex) {\n * //=previousValue\n * //=currentFeature\n * //=currentIndex\n * return currentFeature\n * });\n */\nfunction featureReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(layer, function (currentFeature, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentFeature;\n } else {\n previousValue = callback(previousValue, currentFeature, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.featureReduce = featureReduce;\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {Object} layer any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * var coords = turf.coordAll(features);\n * //=coords\n */\nfunction coordAll(layer) {\n var coords = [];\n coordEach(layer, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\nmodule.exports.coordAll = coordAll;\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomEach(features, function (currentGeometry, currentIndex) {\n * //=currentGeometry\n * //=currentIndex\n * });\n */\nfunction geomEach(layer, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n currentIndex = 0,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n if (geometry.type === 'Point' ||\n geometry.type === 'LineString' ||\n geometry.type === 'MultiPoint' ||\n geometry.type === 'Polygon' ||\n geometry.type === 'MultiLineString' ||\n geometry.type === 'MultiPolygon') {\n callback(geometry, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++) {\n callback(geometry.geometries[j], currentIndex);\n currentIndex++;\n }\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.geomEach = geomEach;\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentGeometry The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomReduce(features, function (previousValue, currentGeometry, currentIndex) {\n * //=previousValue\n * //=currentGeometry\n * //=currentIndex\n * return currentGeometry\n * });\n */\nfunction geomReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(layer, function (currentGeometry, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentGeometry;\n } else {\n previousValue = callback(previousValue, currentGeometry, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.geomReduce = geomReduce;\n","var featureCollection = require('@turf/helpers').featureCollection;\nvar centroid = require('@turf/center');\nvar distance = require('@turf/distance');\nvar inside = require('@turf/inside');\nvar explode = require('@turf/explode');\n\n/**\n * Takes a feature and returns a {@link Point} guaranteed to be on the surface of the feature.\n *\n * * Given a {@link Polygon}, the point will be in the area of the polygon\n * * Given a {@link LineString}, the point will be along the string\n * * Given a {@link Point}, the point will the same as the input\n *\n * @param {(Feature|FeatureCollection)} fc any feature or set of features\n * @returns {Feature} a point on the surface of `input`\n * @example\n * // create a random polygon\n * var polygon = turf.random('polygon');\n *\n * var pointOnPolygon = turf.pointOnSurface(polygon);\n *\n * //addToMap\n * var addToMap = [polygon, pointOnPolygon];\n */\nfunction pointOnSurface(fc) {\n // normalize\n if (fc.type !== 'FeatureCollection') {\n if (fc.type !== 'Feature') {\n fc = {\n type: 'Feature',\n geometry: fc,\n properties: {}\n };\n }\n fc = featureCollection([fc]);\n }\n\n //get centroid\n var cent = centroid(fc);\n\n // check to see if centroid is on surface\n var onSurface = false;\n var i = 0;\n while (!onSurface && i < fc.features.length) {\n var geom = fc.features[i].geometry;\n var x, y, x1, y1, x2, y2, k;\n var onLine = false;\n if (geom.type === 'Point') {\n if (cent.geometry.coordinates[0] === geom.coordinates[0] &&\n cent.geometry.coordinates[1] === geom.coordinates[1]) {\n onSurface = true;\n }\n } else if (geom.type === 'MultiPoint') {\n var onMultiPoint = false;\n k = 0;\n while (!onMultiPoint && k < geom.coordinates.length) {\n if (cent.geometry.coordinates[0] === geom.coordinates[k][0] &&\n cent.geometry.coordinates[1] === geom.coordinates[k][1]) {\n onSurface = true;\n onMultiPoint = true;\n }\n k++;\n }\n } else if (geom.type === 'LineString') {\n k = 0;\n while (!onLine && k < geom.coordinates.length - 1) {\n x = cent.geometry.coordinates[0];\n y = cent.geometry.coordinates[1];\n x1 = geom.coordinates[k][0];\n y1 = geom.coordinates[k][1];\n x2 = geom.coordinates[k + 1][0];\n y2 = geom.coordinates[k + 1][1];\n if (pointOnSegment(x, y, x1, y1, x2, y2)) {\n onLine = true;\n onSurface = true;\n }\n k++;\n }\n } else if (geom.type === 'MultiLineString') {\n var j = 0;\n while (j < geom.coordinates.length) {\n onLine = false;\n k = 0;\n var line = geom.coordinates[j];\n while (!onLine && k < line.length - 1) {\n x = cent.geometry.coordinates[0];\n y = cent.geometry.coordinates[1];\n x1 = line[k][0];\n y1 = line[k][1];\n x2 = line[k + 1][0];\n y2 = line[k + 1][1];\n if (pointOnSegment(x, y, x1, y1, x2, y2)) {\n onLine = true;\n onSurface = true;\n }\n k++;\n }\n j++;\n }\n } else if (geom.type === 'Polygon' || geom.type === 'MultiPolygon') {\n var f = {\n type: 'Feature',\n geometry: geom,\n properties: {}\n };\n if (inside(cent, f)) {\n onSurface = true;\n }\n }\n i++;\n }\n if (onSurface) {\n return cent;\n } else {\n var vertices = featureCollection([]);\n for (i = 0; i < fc.features.length; i++) {\n vertices.features = vertices.features.concat(explode(fc.features[i]).features);\n }\n var closestVertex;\n var closestDistance = Infinity;\n for (i = 0; i < vertices.features.length; i++) {\n var dist = distance(cent, vertices.features[i], 'miles');\n if (dist < closestDistance) {\n closestDistance = dist;\n closestVertex = vertices.features[i];\n }\n }\n return closestVertex;\n }\n}\n\nfunction pointOnSegment(x, y, x1, y1, x2, y2) {\n var ab = Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n var ap = Math.sqrt((x - x1) * (x - x1) + (y - y1) * (y - y1));\n var pb = Math.sqrt((x2 - x) * (x2 - x) + (y2 - y) * (y2 - y));\n if (ab === ap + pb) {\n return true;\n }\n}\n\nmodule.exports = pointOnSurface;\n","var linestring = require('@turf/helpers').lineString;\nvar Spline = require('./spline.js');\n\n/**\n * Takes a {@link LineString|line} and returns a curved version\n * by applying a [Bezier spline](http://en.wikipedia.org/wiki/B%C3%A9zier_spline)\n * algorithm.\n *\n * The bezier spline implementation is by [Leszek Rybicki](http://leszek.rybicki.cc/).\n *\n * @name bezier\n * @param {Feature} line input LineString\n * @param {number} [resolution=10000] time in milliseconds between points\n * @param {number} [sharpness=0.85] a measure of how curvy the path should be between splines\n * @returns {Feature} curved line\n * @example\n * var line = turf.lineString([\n * [-76.091308, 18.427501],\n * [-76.695556, 18.729501],\n * [-76.552734, 19.40443],\n * [-74.61914, 19.134789],\n * [-73.652343, 20.07657],\n * [-73.157958, 20.210656]\n * ]);\n *\n * var curved = turf.bezier(line);\n *\n * //addToMap\n * var addToMap = [line, curved]\n * curved.properties = { stroke: '#0F0' };\n */\nmodule.exports = function (line, resolution, sharpness) {\n var coords = [];\n\n var spline = new Spline({\n points: line.geometry.coordinates.map(function (pt) {\n return {x: pt[0], y: pt[1]};\n }),\n duration: resolution,\n sharpness: sharpness\n });\n\n for (var i = 0; i < spline.duration; i += 10) {\n var pos = spline.pos(i);\n if (Math.floor(i / 100) % 2 === 0) {\n coords.push([pos.x, pos.y]);\n }\n }\n\n return linestring(coords, line.properties);\n};\n","/**\n * GeoJSON BBox\n *\n * @typedef {[number, number, number, number]} BBox\n */\n\n/**\n * GeoJSON Id\n *\n * @typedef {(number|string)} Id\n */\n\n/**\n * GeoJSON FeatureCollection\n *\n * @typedef {Object} FeatureCollection\n * @property {string} type\n * @property {?Id} id\n * @property {?BBox} bbox\n * @property {Feature[]} features\n */\n\n/**\n * GeoJSON Feature\n *\n * @typedef {Object} Feature\n * @property {string} type\n * @property {?Id} id\n * @property {?BBox} bbox\n * @property {*} properties\n * @property {Geometry} geometry\n */\n\n/**\n * GeoJSON Geometry\n *\n * @typedef {Object} Geometry\n * @property {string} type\n * @property {any[]} coordinates\n */\n\n/**\n * Callback for coordEach\n *\n * @callback coordEachCallback\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * Starts at index 0.\n * @param {number} featureIndex The current index of the feature being processed.\n * @param {number} featureSubIndex The current subIndex of the feature being processed.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentCoord, coordIndex, featureIndex, featureSubIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordEach(features, function (currentCoord, coordIndex, featureIndex, featureSubIndex) {\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=featureSubIndex\n * });\n */\nfunction coordEach(geojson, callback, excludeWrapCoord) {\n // Handles null Geometry -- Skips this GeoJSON\n if (geojson === null) return;\n var featureIndex, geometryIndex, j, k, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n coordIndex = 0,\n isGeometryCollection,\n type = geojson.type,\n isFeatureCollection = type === 'FeatureCollection',\n isFeature = type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (featureIndex = 0; featureIndex < stop; featureIndex++) {\n var featureSubIndex = 0;\n\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[featureIndex].geometry :\n (isFeature ? geojson.geometry : geojson));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (geometryIndex = 0; geometryIndex < stopG; geometryIndex++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[geometryIndex] : geometryMaybeCollection;\n\n // Handles null Geometry -- Skips this geometry\n if (geometry === null) continue;\n coords = geometry.coordinates;\n var geomType = geometry.type;\n\n wrapShrink = (excludeWrapCoord && (geomType === 'Polygon' || geomType === 'MultiPolygon')) ? 1 : 0;\n\n switch (geomType) {\n case null:\n break;\n case 'Point':\n callback(coords, coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n featureSubIndex++;\n break;\n case 'LineString':\n case 'MultiPoint':\n for (j = 0; j < coords.length; j++) {\n callback(coords[j], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n featureSubIndex++;\n }\n break;\n case 'Polygon':\n case 'MultiLineString':\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n callback(coords[j][k], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n featureSubIndex++;\n }\n break;\n case 'MultiPolygon':\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length; k++)\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n callback(coords[j][k][l], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n featureSubIndex++;\n }\n break;\n case 'GeometryCollection':\n for (j = 0; j < geometry.geometries.length; j++)\n coordEach(geometry.geometries[j], callback, excludeWrapCoord);\n break;\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureIndex The current index of the feature being processed.\n * @param {number} featureSubIndex The current subIndex of the feature being processed.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {FeatureCollection|Geometry|Feature} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoord, coordIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordReduce(features, function (previousValue, currentCoord, coordIndex, featureIndex, featureSubIndex) {\n * //=previousValue\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=featureSubIndex\n * return currentCoord;\n * });\n */\nfunction coordReduce(geojson, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(geojson, function (currentCoord, coordIndex, featureIndex, featureSubIndex) {\n if (coordIndex === 0 && initialValue === undefined) previousValue = currentCoord;\n else previousValue = callback(previousValue, currentCoord, coordIndex, featureIndex, featureSubIndex);\n }, excludeWrapCoord);\n return previousValue;\n}\n\n/**\n * Callback for propEach\n *\n * @callback propEachCallback\n * @param {Object} currentProperties The current properties being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {(FeatureCollection|Feature)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, featureIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propEach(features, function (currentProperties, featureIndex) {\n * //=currentProperties\n * //=featureIndex\n * });\n */\nfunction propEach(geojson, callback) {\n var i;\n switch (geojson.type) {\n case 'FeatureCollection':\n for (i = 0; i < geojson.features.length; i++) {\n callback(geojson.features[i].properties, i);\n }\n break;\n case 'Feature':\n callback(geojson.properties, 0);\n break;\n }\n}\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current properties being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {(FeatureCollection|Feature)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propReduce(features, function (previousValue, currentProperties, featureIndex) {\n * //=previousValue\n * //=currentProperties\n * //=featureIndex\n * return currentProperties\n * });\n */\nfunction propReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n propEach(geojson, function (currentProperties, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentProperties;\n else previousValue = callback(previousValue, currentProperties, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for featureEach\n *\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.featureEach(features, function (currentFeature, featureIndex) {\n * //=currentFeature\n * //=featureIndex\n * });\n */\nfunction featureEach(geojson, callback) {\n if (geojson.type === 'Feature') {\n callback(geojson, 0);\n } else if (geojson.type === 'FeatureCollection') {\n for (var i = 0; i < geojson.features.length; i++) {\n callback(geojson.features[i], i);\n }\n }\n}\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.featureReduce(features, function (previousValue, currentFeature, featureIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * return currentFeature\n * });\n */\nfunction featureReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(geojson, function (currentFeature, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * var coords = turf.coordAll(features);\n * //= [[26, 37], [36, 53]]\n */\nfunction coordAll(geojson) {\n var coords = [];\n coordEach(geojson, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\n\n/**\n * Callback for geomEach\n *\n * @callback geomEachCallback\n * @param {Geometry} currentGeometry The current geometry being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} currentProperties The current feature properties being processed.\n */\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, featureIndex, currentProperties)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomEach(features, function (currentGeometry, featureIndex, currentProperties) {\n * //=currentGeometry\n * //=featureIndex\n * //=currentProperties\n * });\n */\nfunction geomEach(geojson, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n geometryProperties,\n featureIndex = 0,\n isFeatureCollection = geojson.type === 'FeatureCollection',\n isFeature = geojson.type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[i].geometry :\n (isFeature ? geojson.geometry : geojson));\n geometryProperties = (isFeatureCollection ? geojson.features[i].properties :\n (isFeature ? geojson.properties : {}));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n // Handle null Geometry\n if (geometry === null) {\n callback(null, featureIndex, geometryProperties);\n featureIndex++;\n continue;\n }\n switch (geometry.type) {\n case 'Point':\n case 'LineString':\n case 'MultiPoint':\n case 'Polygon':\n case 'MultiLineString':\n case 'MultiPolygon': {\n callback(geometry, featureIndex, geometryProperties);\n featureIndex++;\n break;\n }\n case 'GeometryCollection': {\n for (j = 0; j < geometry.geometries.length; j++) {\n callback(geometry.geometries[j], featureIndex, geometryProperties);\n featureIndex++;\n }\n break;\n }\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Geometry} currentGeometry The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {Object} currentProperties The current feature properties being processed.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, featureIndex, currentProperties)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomReduce(features, function (previousValue, currentGeometry, featureIndex, currentProperties) {\n * //=previousValue\n * //=currentGeometry\n * //=featureIndex\n * //=currentProperties\n * return currentGeometry\n * });\n */\nfunction geomReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(geojson, function (currentGeometry, currentIndex, currentProperties) {\n if (currentIndex === 0 && initialValue === undefined) previousValue = currentGeometry;\n else previousValue = callback(previousValue, currentGeometry, currentIndex, currentProperties);\n });\n return previousValue;\n}\n\n/**\n * Callback for flattenEach\n *\n * @callback flattenEachCallback\n * @param {Feature} currentFeature The current flattened feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureSubIndex The subindex of the current element being processed in the\n * array. Starts at index 0 and increases if the flattened feature was a multi-geometry.\n */\n\n/**\n * Iterate over flattened features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name flattenEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex, featureSubIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenEach(features, function (currentFeature, featureIndex, featureSubIndex) {\n * //=currentFeature\n * //=featureIndex\n * //=featureSubIndex\n * });\n */\nfunction flattenEach(geojson, callback) {\n geomEach(geojson, function (geometry, featureIndex, properties) {\n // Callback for single geometry\n var type = (geometry === null) ? null : geometry.type;\n switch (type) {\n case null:\n case 'Point':\n case 'LineString':\n case 'Polygon':\n callback(feature(geometry, properties), featureIndex, 0);\n return;\n }\n\n var geomType;\n\n // Callback for multi-geometry\n switch (type) {\n case 'MultiPoint':\n geomType = 'Point';\n break;\n case 'MultiLineString':\n geomType = 'LineString';\n break;\n case 'MultiPolygon':\n geomType = 'Polygon';\n break;\n }\n\n geometry.coordinates.forEach(function (coordinate, featureSubIndex) {\n var geom = {\n type: geomType,\n coordinates: coordinate\n };\n callback(feature(geom, properties), featureIndex, featureSubIndex);\n });\n\n });\n}\n\n/**\n * Callback for flattenReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback flattenReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureSubIndex The subindex of the current element being processed in the\n * array. Starts at index 0 and increases if the flattened feature was a multi-geometry.\n */\n\n/**\n * Reduce flattened features in any GeoJSON object, similar to Array.reduce().\n *\n * @name flattenReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex, featureSubIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenReduce(features, function (previousValue, currentFeature, featureIndex, featureSubIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * //=featureSubIndex\n * return currentFeature\n * });\n */\nfunction flattenReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n flattenEach(geojson, function (currentFeature, featureIndex, featureSubIndex) {\n if (featureIndex === 0 && featureSubIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex, featureSubIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for segmentEach\n *\n * @callback segmentEachCallback\n * @param {Feature} currentSegment The current segment being processed.\n * @param {number} featureIndex The index of the current element being processed in the array, starts at index 0.\n * @param {number} featureSubIndex The subindex of the current element being processed in the\n * array. Starts at index 0 and increases for each iterating line segment.\n * @returns {void}\n */\n\n/**\n * Iterate over 2-vertex line segment in any GeoJSON object, similar to Array.forEach()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON\n * @param {Function} callback a method that takes (currentSegment, featureIndex, featureSubIndex)\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentEach(polygon, function (currentSegment, featureIndex, featureSubIndex) {\n * //= currentSegment\n * //= featureIndex\n * //= featureSubIndex\n * });\n *\n * // Calculate the total number of segments\n * var total = 0;\n * var initialValue = 0;\n * turf.segmentEach(polygon, function () {\n * total++;\n * }, initialValue);\n */\nfunction segmentEach(geojson, callback) {\n flattenEach(geojson, function (feature, featureIndex) {\n var featureSubIndex = 0;\n // Exclude null Geometries\n if (!feature.geometry) return;\n // (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n var type = feature.geometry.type;\n if (type === 'Point' || type === 'MultiPoint') return;\n\n // Generate 2-vertex line segments\n coordReduce(feature, function (previousCoords, currentCoord) {\n var currentSegment = lineString([previousCoords, currentCoord], feature.properties);\n callback(currentSegment, featureIndex, featureSubIndex);\n featureSubIndex++;\n return currentCoord;\n });\n });\n}\n\n/**\n * Callback for segmentReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback segmentReduceCallback\n * @param {*} [previousValue] The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} [currentSegment] The current segment being processed.\n * @param {number} [currentIndex] The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} [currentSubIndex] The subindex of the current element being processed in the\n * array. Starts at index 0 and increases for each iterating line segment.\n */\n\n/**\n * Reduce 2-vertex line segment in any GeoJSON object, similar to Array.reduce()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON\n * @param {Function} callback a method that takes (previousValue, currentSegment, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentReduce(polygon, function (previousSegment, currentSegment, currentIndex, currentSubIndex) {\n * //= previousSegment\n * //= currentSegment\n * //= currentIndex\n * //= currentSubIndex\n * return currentSegment\n * });\n *\n * // Calculate the total number of segments\n * var initialValue = 0\n * var total = turf.segmentReduce(polygon, function (previousValue) {\n * previousValue++;\n * return previousValue;\n * }, initialValue);\n */\nfunction segmentReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n segmentEach(geojson, function (currentSegment, currentIndex, currentSubIndex) {\n if (currentIndex === 0 && initialValue === undefined) previousValue = currentSegment;\n else previousValue = callback(previousValue, currentSegment, currentIndex, currentSubIndex);\n });\n return previousValue;\n}\n\n/**\n * Create Feature\n *\n * @private\n * @param {Geometry} geometry GeoJSON Geometry\n * @param {Object} properties Properties\n * @returns {Feature} GeoJSON Feature\n */\nfunction feature(geometry, properties) {\n if (geometry === undefined) throw new Error('No geometry passed');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: geometry\n };\n}\n\n/**\n * Create LineString\n *\n * @private\n * @param {Array>} coordinates Line Coordinates\n * @param {Object} properties Properties\n * @returns {Feature} GeoJSON LineString Feature\n */\nfunction lineString(coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length < 2) throw new Error('Coordinates must be an array of two or more positions');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: {\n type: 'LineString',\n coordinates: coordinates\n }\n };\n}\n\n\n/**\n * Callback for lineEach\n *\n * @callback lineEachCallback\n * @param {Feature} currentLine The current LineString|LinearRing being processed.\n * @param {number} lineIndex The index of the current element being processed in the array, starts at index 0.\n * @param {number} lineSubIndex The sub-index of the current line being processed at index 0\n */\n\n/**\n * Iterate over line or ring coordinates in LineString, Polygon, MultiLineString, MultiPolygon Features or Geometries,\n * similar to Array.forEach.\n *\n * @name lineEach\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (currentLine, lineIndex, lineSubIndex)\n * @example\n * var mtLn = turf.multiLineString([\n * turf.lineString([[26, 37], [35, 45]]),\n * turf.lineString([[36, 53], [38, 50], [41, 55]])\n * ]);\n *\n * turf.lineEach(mtLn, function (currentLine, lineIndex) {\n * //=currentLine\n * //=lineIndex\n * });\n */\nfunction lineEach(geojson, callback) {\n // validation\n if (!geojson) throw new Error('geojson is required');\n var type = geojson.geometry ? geojson.geometry.type : geojson.type;\n if (!type) throw new Error('invalid geojson');\n if (type === 'FeatureCollection') throw new Error('FeatureCollection is not supported');\n if (type === 'GeometryCollection') throw new Error('GeometryCollection is not supported');\n var coordinates = geojson.geometry ? geojson.geometry.coordinates : geojson.coordinates;\n if (!coordinates) throw new Error('geojson must contain coordinates');\n\n switch (type) {\n case 'LineString':\n callback(coordinates, 0, 0);\n return;\n case 'Polygon':\n case 'MultiLineString':\n var subIndex = 0;\n for (var line = 0; line < coordinates.length; line++) {\n if (type === 'MultiLineString') subIndex = line;\n callback(coordinates[line], line, subIndex);\n }\n return;\n case 'MultiPolygon':\n for (var multi = 0; multi < coordinates.length; multi++) {\n for (var ring = 0; ring < coordinates[multi].length; ring++) {\n callback(coordinates[multi][ring], ring, multi);\n }\n }\n return;\n default:\n throw new Error(type + ' geometry not supported');\n }\n}\n\n/**\n * Callback for lineReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback lineReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentLine The current LineString|LinearRing being processed.\n * @param {number} lineIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} lineSubIndex The sub-index of the current line being processed at index 0\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name lineReduce\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var mtp = turf.multiPolygon([\n * turf.polygon([[[12,48],[2,41],[24,38],[12,48]], [[9,44],[13,41],[13,45],[9,44]]]),\n * turf.polygon([[[5, 5], [0, 0], [2, 2], [4, 4], [5, 5]]])\n * ]);\n *\n * turf.lineReduce(mtp, function (previousValue, currentLine, lineIndex, lineSubIndex) {\n * //=previousValue\n * //=currentLine\n * //=lineIndex\n * //=lineSubIndex\n * return currentLine\n * }, 2);\n */\nfunction lineReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n lineEach(geojson, function (currentLine, lineIndex, lineSubIndex) {\n if (lineIndex === 0 && initialValue === undefined) previousValue = currentLine;\n else previousValue = callback(previousValue, currentLine, lineIndex, lineSubIndex);\n });\n return previousValue;\n}\n\nmodule.exports = {\n coordEach: coordEach,\n coordReduce: coordReduce,\n propEach: propEach,\n propReduce: propReduce,\n featureEach: featureEach,\n featureReduce: featureReduce,\n coordAll: coordAll,\n geomEach: geomEach,\n geomReduce: geomReduce,\n flattenEach: flattenEach,\n flattenReduce: flattenReduce,\n segmentEach: segmentEach,\n segmentReduce: segmentReduce,\n lineEach: lineEach,\n lineReduce: lineReduce\n};\n","'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Node = require('./Node'),\n Edge = require('./Edge'),\n EdgeRing = require('./EdgeRing'),\n _require = require('@turf/meta'),\n flattenEach = _require.flattenEach,\n coordReduce = _require.coordReduce,\n _require2 = require('@turf/invariant'),\n featureOf = _require2.featureOf;\n\n/** Validates the geoJson.\n *\n * @param {Geojson} geoJson - input geoJson.\n * @throws {Error} if geoJson is invalid.\n */\nfunction validateGeoJson(geoJson) {\n if (!geoJson) throw new Error('No geojson passed');\n\n if (geoJson.type !== 'FeatureCollection' && geoJson.type !== 'GeometryCollection' && geoJson.type !== 'MultiLineString' && geoJson.type !== 'LineString' && geoJson.type !== 'Feature') throw new Error('Invalid input type \\'' + geoJson.type + '\\'. Geojson must be FeatureCollection, GeometryCollection, LineString, MultiLineString or Feature');\n}\n\n/** Represents a planar graph of edges and nodes that can be used to compute a\n * polygonization.\n *\n * Although, this class is inspired by GEOS's `geos::operation::polygonize::PolygonizeGraph`,\n * it isn't a rewrite. As regards algorithm, this class implements the same logic, but it\n * isn't a javascript transcription of the C++ source.\n *\n * This graph is directed (both directions are created)\n */\n\nvar Graph = function () {\n _createClass(Graph, [{\n key: 'getNode',\n\n\n /** Creates or get a Node.\n *\n * @param {Number[]} coordinates - Coordinates of the node\n * @returns {Node} - The created or stored node\n */\n value: function getNode(coordinates) {\n var id = Node.buildId(coordinates);\n var node = this.nodes[id];\n if (!node) node = this.nodes[id] = new Node(coordinates);\n\n return node;\n }\n\n /** Adds an Edge and its symetricall.\n * Edges are added symetrically, i.e.: we also add its symetric\n *\n * @param {Node} from - Node which starts the Edge\n * @param {Node} to - Node which ends the Edge\n */\n\n }, {\n key: 'addEdge',\n value: function addEdge(from, to) {\n var edge = new Edge(from, to),\n symetricEdge = edge.getSymetric();\n\n this.edges.push(edge);\n this.edges.push(symetricEdge);\n }\n }], [{\n key: 'fromGeoJson',\n\n /** Creates a graph from a GeoJSON.\n *\n * @param {FeatureCollection} geoJson - it must comply with the restrictions detailed in the index\n * @returns {Graph} - The newly created graph\n * @throws {Error} if geoJson is invalid.\n */\n value: function fromGeoJson(geoJson) {\n validateGeoJson(geoJson);\n\n var graph = new Graph();\n flattenEach(geoJson, function (feature) {\n featureOf(feature, 'LineString', 'Graph::fromGeoJson');\n // When a LineString if formed by many segments, split them\n coordReduce(feature, function (prev, cur) {\n if (prev) {\n var start = graph.getNode(prev),\n end = graph.getNode(cur);\n\n graph.addEdge(start, end);\n }\n return cur;\n });\n });\n\n return graph;\n }\n }]);\n\n function Graph() {\n _classCallCheck(this, Graph);\n\n this.edges = []; //< {Edge[]} dirEdges\n\n // The key is the `id` of the Node (ie: coordinates.join(','))\n this.nodes = {};\n }\n\n /** Removes Dangle Nodes (nodes with grade 1).\n */\n\n\n _createClass(Graph, [{\n key: 'deleteDangles',\n value: function deleteDangles() {\n var _this = this;\n\n Object.keys(this.nodes).map(function (id) {\n return _this.nodes[id];\n }).forEach(function (node) {\n return _this._removeIfDangle(node);\n });\n }\n\n /** Check if node is dangle, if so, remove it.\n * It calls itself recursively, removing a dangling node might cause another dangling node\n *\n * @param {Node} node - Node to check if it's a dangle\n */\n\n }, {\n key: '_removeIfDangle',\n value: function _removeIfDangle(node) {\n var _this2 = this;\n\n // As edges are directed and symetrical, we count only innerEdges\n if (node.innerEdges.length <= 1) {\n var outerNodes = node.getOuterEdges().map(function (e) {\n return e.to;\n });\n this.removeNode(node);\n outerNodes.forEach(function (n) {\n return _this2._removeIfDangle(n);\n });\n }\n }\n\n /** Delete cut-edges (bridge edges).\n *\n * The graph will be traversed, all the edges will be labeled according the ring\n * in which they are. (The label is a number incremented by 1). Edges with the same\n * label are cut-edges.\n */\n\n }, {\n key: 'deleteCutEdges',\n value: function deleteCutEdges() {\n var _this3 = this;\n\n this._computeNextCWEdges();\n this._findLabeledEdgeRings();\n\n // Cut-edges (bridges) are edges where both edges have the same label\n this.edges.forEach(function (edge) {\n if (edge.label === edge.symetric.label) {\n _this3.removeEdge(edge.symetric);\n _this3.removeEdge(edge);\n }\n });\n }\n\n /** Set the `next` property of each Edge.\n * The graph will be transversed in a CW form, so, we set the next of the symetrical edge as the previous one.\n * OuterEdges are sorted CCW.\n *\n * @param {Node} [node] - If no node is passed, the function calls itself for every node in the Graph\n */\n\n }, {\n key: '_computeNextCWEdges',\n value: function _computeNextCWEdges(node) {\n var _this4 = this;\n\n if (typeof node === 'undefined') {\n Object.keys(this.nodes).forEach(function (id) {\n return _this4._computeNextCWEdges(_this4.nodes[id]);\n });\n } else {\n node.getOuterEdges().forEach(function (edge, i) {\n node.getOuterEdge((i === 0 ? node.getOuterEdges().length : i) - 1).symetric.next = edge;\n });\n }\n }\n\n /** Computes the next edge pointers going CCW around the given node, for the given edgering label.\n * This algorithm has the effect of converting maximal edgerings into minimal edgerings\n *\n * XXX: method literally transcribed from `geos::operation::polygonize::PolygonizeGraph::computeNextCCWEdges`,\n * could be written in a more javascript way.\n *\n * @param {Node} node - Node\n * @param {Number} label - Ring's label\n */\n\n }, {\n key: '_computeNextCCWEdges',\n value: function _computeNextCCWEdges(node, label) {\n var edges = node.getOuterEdges();\n var firstOutDE = void 0,\n prevInDE = void 0;\n\n for (var i = edges.length - 1; i >= 0; --i) {\n var de = edges[i],\n sym = de.symetric,\n outDE = void 0,\n inDE = void 0;\n\n if (de.label === label) outDE = de;\n\n if (sym.label === label) inDE = sym;\n\n if (!outDE || !inDE) // This edge is not in edgering\n continue;\n\n if (inDE) prevInDE = inDE;\n\n if (outDE) {\n if (prevInDE) {\n prevInDE.next = outDE;\n prevInDE = undefined;\n }\n\n if (!firstOutDE) firstOutDE = outDE;\n }\n }\n\n if (prevInDE) prevInDE.next = firstOutDE;\n }\n\n /** Finds rings and labels edges according to which rings are.\n * The label is a number which is increased for each ring.\n *\n * @returns {Edge[]} edges that start rings\n */\n\n }, {\n key: '_findLabeledEdgeRings',\n value: function _findLabeledEdgeRings() {\n var edgeRingStarts = [];\n var label = 0;\n this.edges.forEach(function (edge) {\n if (edge.label >= 0) return;\n\n edgeRingStarts.push(edge);\n\n var e = edge;\n do {\n e.label = label;\n e = e.next;\n } while (!edge.isEqual(e));\n\n label++;\n });\n\n return edgeRingStarts;\n }\n\n /** Computes the EdgeRings formed by the edges in this graph.\n *\n * @returns {EdgeRing[]} - A list of all the EdgeRings in the graph.\n */\n\n }, {\n key: 'getEdgeRings',\n value: function getEdgeRings() {\n var _this5 = this;\n\n this._computeNextCWEdges();\n\n // Clear labels\n this.edges.forEach(function (edge) {\n edge.label = undefined;\n });\n\n this._findLabeledEdgeRings().forEach(function (edge) {\n // convertMaximalToMinimalEdgeRings\n _this5._findIntersectionNodes(edge).forEach(function (node) {\n _this5._computeNextCCWEdges(node, edge.label);\n });\n });\n\n var edgeRingList = [];\n\n // find all edgerings\n this.edges.forEach(function (edge) {\n if (edge.ring) return;\n edgeRingList.push(_this5._findEdgeRing(edge));\n });\n\n return edgeRingList;\n }\n\n /** Find all nodes in a Maxima EdgeRing which are self-intersection nodes.\n *\n * @param {Node} startEdge - Start Edge of the Ring\n * @returns {Node[]} - intersection nodes\n */\n\n }, {\n key: '_findIntersectionNodes',\n value: function _findIntersectionNodes(startEdge) {\n var intersectionNodes = [];\n var edge = startEdge;\n\n var _loop = function _loop() {\n // getDegree\n var degree = 0;\n edge.from.getOuterEdges().forEach(function (e) {\n if (e.label === startEdge.label) ++degree;\n });\n\n if (degree > 1) intersectionNodes.push(edge.from);\n\n edge = edge.next;\n };\n\n do {\n _loop();\n } while (!startEdge.isEqual(edge));\n\n return intersectionNodes;\n }\n\n /** Get the edge-ring which starts from the provided Edge.\n *\n * @param {Edge} startEdge - starting edge of the edge ring\n * @returns {EdgeRing} - EdgeRing which start Edge is the provided one.\n */\n\n }, {\n key: '_findEdgeRing',\n value: function _findEdgeRing(startEdge) {\n var edge = startEdge;\n var edgeRing = new EdgeRing();\n\n do {\n edgeRing.push(edge);\n edge.ring = edgeRing;\n edge = edge.next;\n } while (!startEdge.isEqual(edge));\n\n return edgeRing;\n }\n\n /** Removes a node from the Graph.\n *\n * It also removes edges asociated to that node\n * @param {Node} node - Node to be removed\n */\n\n }, {\n key: 'removeNode',\n value: function removeNode(node) {\n var _this6 = this;\n\n node.getOuterEdges().forEach(function (edge) {\n return _this6.removeEdge(edge);\n });\n node.innerEdges.forEach(function (edge) {\n return _this6.removeEdge(edge);\n });\n delete this.nodes[node.id];\n }\n\n /** Remove edge from the graph and deletes the edge.\n *\n * @param {Edge} edge - Edge to be removed\n */\n\n }, {\n key: 'removeEdge',\n value: function removeEdge(edge) {\n this.edges = this.edges.filter(function (e) {\n return !e.isEqual(edge);\n });\n edge.deleteEdge();\n }\n }]);\n\n return Graph;\n}();\n\nmodule.exports = Graph;","//index.js\nvar deepEqual = require('deep-equal');\n\nvar Equality = function(opt) {\n this.precision = opt && opt.precision ? opt.precision : 17;\n this.direction = opt && opt.direction ? opt.direction : false;\n this.pseudoNode = opt && opt.pseudoNode ? opt.pseudoNode : false;\n this.objectComparator = opt && opt.objectComparator ? opt.objectComparator : objectComparator;\n};\n\nEquality.prototype.compare = function(g1,g2) {\n if (g1.type !== g2.type || !sameLength(g1,g2)) return false;\n\n switch(g1.type) {\n case 'Point':\n return this.compareCoord(g1.coordinates, g2.coordinates);\n break;\n case 'LineString':\n return this.compareLine(g1.coordinates, g2.coordinates,0,false);\n break;\n case 'Polygon':\n return this.comparePolygon(g1,g2);\n break;\n case 'Feature':\n return this.compareFeature(g1, g2);\n default:\n if (g1.type.indexOf('Multi') === 0) {\n var context = this;\n var g1s = explode(g1);\n var g2s = explode(g2);\n return g1s.every(function(g1part) {\n return this.some(function(g2part) {\n return context.compare(g1part,g2part);\n });\n },g2s);\n }\n }\n return false;\n};\n\nfunction explode(g) {\n return g.coordinates.map(function(part) {\n return {\n type: g.type.replace('Multi', ''),\n coordinates: part}\n });\n}\n//compare length of coordinates/array\nfunction sameLength(g1,g2) {\n return g1.hasOwnProperty('coordinates') ?\n g1.coordinates.length === g2.coordinates.length\n : g1.length === g2.length;\n}\n\n// compare the two coordinates [x,y]\nEquality.prototype.compareCoord = function(c1,c2) {\n if (c1.length !== c2.length) {\n return false;\n }\n\n for (var i=0; i < c1.length; i++) {\n if (c1[i].toFixed(this.precision) !== c2[i].toFixed(this.precision)) {\n return false;\n }\n }\n return true;\n};\n\nEquality.prototype.compareLine = function(path1,path2,ind,isPoly) {\n if (!sameLength(path1,path2)) return false;\n var p1 = this.pseudoNode ? path1 : this.removePseudo(path1);\n var p2 = this.pseudoNode ? path2 : this.removePseudo(path2);\n if (isPoly && !this.compareCoord(p1[0],p2[0])) {\n // fix start index of both to same point\n p2 = this.fixStartIndex(p2,p1);\n if(!p2) return;\n }\n // for linestring ind =0 and for polygon ind =1\n var sameDirection = this.compareCoord(p1[ind],p2[ind]);\n if (this.direction || sameDirection\n ) {\n return this.comparePath(p1, p2);\n } else {\n if (this.compareCoord(p1[ind],p2[p2.length - (1+ind)])\n ) {\n return this.comparePath(p1.slice().reverse(), p2);\n }\n return false;\n }\n};\nEquality.prototype.fixStartIndex = function(sourcePath,targetPath) {\n //make sourcePath first point same as of targetPath\n var correctPath,ind = -1;\n for (var i=0; i< sourcePath.length; i++) {\n if(this.compareCoord(sourcePath[i],targetPath[0])) {\n ind = i;\n break;\n }\n }\n if (ind >= 0) {\n correctPath = [].concat(\n sourcePath.slice(ind,sourcePath.length),\n sourcePath.slice(1,ind+1));\n }\n return correctPath;\n};\nEquality.prototype.comparePath = function (p1,p2) {\n var cont = this;\n return p1.every(function(c,i) {\n return cont.compareCoord(c,this[i]);\n },p2);\n};\n\nEquality.prototype.comparePolygon = function(g1,g2) {\n if (this.compareLine(g1.coordinates[0],g2.coordinates[0],1,true)) {\n var holes1 = g1.coordinates.slice(1,g1.coordinates.length);\n var holes2 = g2.coordinates.slice(1,g2.coordinates.length);\n var cont = this;\n return holes1.every(function(h1) {\n return this.some(function(h2) {\n return cont.compareLine(h1,h2,1,true);\n });\n },holes2);\n } else {\n return false;\n }\n};\n\nEquality.prototype.compareFeature = function(g1,g2) {\n if (\n g1.id !== g2.id ||\n !this.objectComparator(g1.properties, g2.properties) ||\n !this.compareBBox(g1,g2)\n ) {\n return false;\n }\n return this.compare(g1.geometry, g2.geometry);\n};\n\nEquality.prototype.compareBBox = function(g1,g2) {\n if (\n (!g1.bbox && !g2.bbox) || \n (\n g1.bbox && g2.bbox &&\n this.compareCoord(g1.bbox, g2.bbox)\n )\n ) {\n return true;\n }\n return false;\n};\nEquality.prototype.removePseudo = function(path) {\n //TODO to be implement\n return path;\n};\n\nfunction objectComparator(obj1, obj2) {\n return deepEqual(obj1, obj2, {strict: true});\n}\n\nmodule.exports = Equality;\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Ordnance Survey Grid Reference functions (c) Chris Veness 2005-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-gridref.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-osgridref.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var LatLon = require('./latlon-ellipsoidal.js'); // ≡ import LatLon from 'latlon-ellipsoidal.js'\n\n\n/**\n * Convert OS grid references to/from OSGB latitude/longitude points.\n *\n * Formulation implemented here due to Thomas, Redfearn, etc is as published by OS, but is inferior\n * to Krüger as used by e.g. Karney 2011.\n *\n * www.ordnancesurvey.co.uk/docs/support/guide-coordinate-systems-great-britain.pdf.\n *\n * @module osgridref\n * @requires latlon-ellipsoidal\n */\n/*\n * Converted 2015 to work with WGS84 by default, OSGB36 as option;\n * www.ordnancesurvey.co.uk/blog/2014/12/confirmation-on-changes-to-latitude-and-longitude\n */\n\n\n/**\n * Creates an OsGridRef object.\n *\n * @constructor\n * @param {number} easting - Easting in metres from OS false origin.\n * @param {number} northing - Northing in metres from OS false origin.\n *\n * @example\n * var grid = new OsGridRef(651409, 313177);\n */\nfunction OsGridRef(easting, northing) {\n // allow instantiation without 'new'\n if (!(this instanceof OsGridRef)) return new OsGridRef(easting, northing);\n\n this.easting = Number(easting);\n this.northing = Number(northing);\n}\n\n\n/**\n * Converts latitude/longitude to Ordnance Survey grid reference easting/northing coordinate.\n *\n * Note formulation implemented here due to Thomas, Redfearn, etc is as published by OS, but is\n * inferior to Krüger as used by e.g. Karney 2011.\n *\n * @param {LatLon} point - latitude/longitude.\n * @returns {OsGridRef} OS Grid Reference easting/northing.\n *\n * @example\n * var p = new LatLon(52.65798, 1.71605);\n * var grid = OsGridRef.latLonToOsGrid(p); // grid.toString(): TG 51409 13177\n * // for conversion of (historical) OSGB36 latitude/longitude point:\n * var p = new LatLon(52.65757, 1.71791, LatLon.datum.OSGB36);\n */\nOsGridRef.latLonToOsGrid = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // if necessary convert to OSGB36 first\n if (point.datum != LatLon.datum.OSGB36) point = point.convertDatum(LatLon.datum.OSGB36);\n\n var φ = point.lat.toRadians();\n var λ = point.lon.toRadians();\n\n var a = 6377563.396, b = 6356256.909; // Airy 1830 major & minor semi-axes\n var F0 = 0.9996012717; // NatGrid scale factor on central meridian\n var φ0 = (49).toRadians(), λ0 = (-2).toRadians(); // NatGrid true origin is 49°N,2°W\n var N0 = -100000, E0 = 400000; // northing & easting of true origin, metres\n var e2 = 1 - (b*b)/(a*a); // eccentricity squared\n var n = (a-b)/(a+b), n2 = n*n, n3 = n*n*n; // n, n², n³\n\n var cosφ = Math.cos(φ), sinφ = Math.sin(φ);\n var ν = a*F0/Math.sqrt(1-e2*sinφ*sinφ); // nu = transverse radius of curvature\n var ρ = a*F0*(1-e2)/Math.pow(1-e2*sinφ*sinφ, 1.5); // rho = meridional radius of curvature\n var η2 = ν/ρ-1; // eta = ?\n\n var Ma = (1 + n + (5/4)*n2 + (5/4)*n3) * (φ-φ0);\n var Mb = (3*n + 3*n*n + (21/8)*n3) * Math.sin(φ-φ0) * Math.cos(φ+φ0);\n var Mc = ((15/8)*n2 + (15/8)*n3) * Math.sin(2*(φ-φ0)) * Math.cos(2*(φ+φ0));\n var Md = (35/24)*n3 * Math.sin(3*(φ-φ0)) * Math.cos(3*(φ+φ0));\n var M = b * F0 * (Ma - Mb + Mc - Md); // meridional arc\n\n var cos3φ = cosφ*cosφ*cosφ;\n var cos5φ = cos3φ*cosφ*cosφ;\n var tan2φ = Math.tan(φ)*Math.tan(φ);\n var tan4φ = tan2φ*tan2φ;\n\n var I = M + N0;\n var II = (ν/2)*sinφ*cosφ;\n var III = (ν/24)*sinφ*cos3φ*(5-tan2φ+9*η2);\n var IIIA = (ν/720)*sinφ*cos5φ*(61-58*tan2φ+tan4φ);\n var IV = ν*cosφ;\n var V = (ν/6)*cos3φ*(ν/ρ-tan2φ);\n var VI = (ν/120) * cos5φ * (5 - 18*tan2φ + tan4φ + 14*η2 - 58*tan2φ*η2);\n\n var Δλ = λ-λ0;\n var Δλ2 = Δλ*Δλ, Δλ3 = Δλ2*Δλ, Δλ4 = Δλ3*Δλ, Δλ5 = Δλ4*Δλ, Δλ6 = Δλ5*Δλ;\n\n var N = I + II*Δλ2 + III*Δλ4 + IIIA*Δλ6;\n var E = E0 + IV*Δλ + V*Δλ3 + VI*Δλ5;\n\n N = Number(N.toFixed(3)); // round to mm precision\n E = Number(E.toFixed(3));\n\n return new OsGridRef(E, N); // gets truncated to SW corner of 1m grid square\n};\n\n\n/**\n * Converts Ordnance Survey grid reference easting/northing coordinate to latitude/longitude\n * (SW corner of grid square).\n *\n * Note formulation implemented here due to Thomas, Redfearn, etc is as published by OS, but is\n * inferior to Krüger as used by e.g. Karney 2011.\n *\n * @param {OsGridRef} gridref - Grid ref E/N to be converted to lat/long (SW corner of grid square).\n * @param {LatLon.datum} [datum=WGS84] - Datum to convert grid reference into.\n * @returns {LatLon} Latitude/longitude of supplied grid reference.\n *\n * @example\n * var gridref = new OsGridRef(651409.903, 313177.270);\n * var pWgs84 = OsGridRef.osGridToLatLon(gridref); // 52°39′28.723″N, 001°42′57.787″E\n * // to obtain (historical) OSGB36 latitude/longitude point:\n * var pOsgb = OsGridRef.osGridToLatLon(gridref, LatLon.datum.OSGB36); // 52°39′27.253″N, 001°43′04.518″E\n */\nOsGridRef.osGridToLatLon = function(gridref, datum) {\n if (!(gridref instanceof OsGridRef)) throw new TypeError('gridref is not OsGridRef object');\n if (datum === undefined) datum = LatLon.datum.WGS84;\n\n var E = gridref.easting;\n var N = gridref.northing;\n\n var a = 6377563.396, b = 6356256.909; // Airy 1830 major & minor semi-axes\n var F0 = 0.9996012717; // NatGrid scale factor on central meridian\n var φ0 = (49).toRadians(), λ0 = (-2).toRadians(); // NatGrid true origin is 49°N,2°W\n var N0 = -100000, E0 = 400000; // northing & easting of true origin, metres\n var e2 = 1 - (b*b)/(a*a); // eccentricity squared\n var n = (a-b)/(a+b), n2 = n*n, n3 = n*n*n; // n, n², n³\n\n var φ=φ0, M=0;\n do {\n φ = (N-N0-M)/(a*F0) + φ;\n\n var Ma = (1 + n + (5/4)*n2 + (5/4)*n3) * (φ-φ0);\n var Mb = (3*n + 3*n*n + (21/8)*n3) * Math.sin(φ-φ0) * Math.cos(φ+φ0);\n var Mc = ((15/8)*n2 + (15/8)*n3) * Math.sin(2*(φ-φ0)) * Math.cos(2*(φ+φ0));\n var Md = (35/24)*n3 * Math.sin(3*(φ-φ0)) * Math.cos(3*(φ+φ0));\n M = b * F0 * (Ma - Mb + Mc - Md); // meridional arc\n\n } while (N-N0-M >= 0.00001); // ie until < 0.01mm\n\n var cosφ = Math.cos(φ), sinφ = Math.sin(φ);\n var ν = a*F0/Math.sqrt(1-e2*sinφ*sinφ); // nu = transverse radius of curvature\n var ρ = a*F0*(1-e2)/Math.pow(1-e2*sinφ*sinφ, 1.5); // rho = meridional radius of curvature\n var η2 = ν/ρ-1; // eta = ?\n\n var tanφ = Math.tan(φ);\n var tan2φ = tanφ*tanφ, tan4φ = tan2φ*tan2φ, tan6φ = tan4φ*tan2φ;\n var secφ = 1/cosφ;\n var ν3 = ν*ν*ν, ν5 = ν3*ν*ν, ν7 = ν5*ν*ν;\n var VII = tanφ/(2*ρ*ν);\n var VIII = tanφ/(24*ρ*ν3)*(5+3*tan2φ+η2-9*tan2φ*η2);\n var IX = tanφ/(720*ρ*ν5)*(61+90*tan2φ+45*tan4φ);\n var X = secφ/ν;\n var XI = secφ/(6*ν3)*(ν/ρ+2*tan2φ);\n var XII = secφ/(120*ν5)*(5+28*tan2φ+24*tan4φ);\n var XIIA = secφ/(5040*ν7)*(61+662*tan2φ+1320*tan4φ+720*tan6φ);\n\n var dE = (E-E0), dE2 = dE*dE, dE3 = dE2*dE, dE4 = dE2*dE2, dE5 = dE3*dE2, dE6 = dE4*dE2, dE7 = dE5*dE2;\n φ = φ - VII*dE2 + VIII*dE4 - IX*dE6;\n var λ = λ0 + X*dE - XI*dE3 + XII*dE5 - XIIA*dE7;\n\n var point = new LatLon(φ.toDegrees(), λ.toDegrees(), LatLon.datum.OSGB36);\n if (datum != LatLon.datum.OSGB36) point = point.convertDatum(datum);\n\n return point;\n};\n\n\n/**\n * Parses grid reference to OsGridRef object.\n *\n * Accepts standard grid references (eg 'SU 387 148'), with or without whitespace separators, from\n * two-digit references up to 10-digit references (1m × 1m square), or fully numeric comma-separated\n * references in metres (eg '438700,114800').\n *\n * @param {string} gridref - Standard format OS grid reference.\n * @returns {OsGridRef} Numeric version of grid reference in metres from false origin (SW corner of\n * supplied grid square).\n * @throws Error on Invalid grid reference.\n *\n * @example\n * var grid = OsGridRef.parse('TG 51409 13177'); // grid: { easting: 651409, northing: 313177 }\n */\nOsGridRef.parse = function(gridref) {\n gridref = String(gridref).trim();\n\n // check for fully numeric comma-separated gridref format\n var match = gridref.match(/^(\\d+),\\s*(\\d+)$/);\n if (match) return new OsGridRef(match[1], match[2]);\n\n // validate format\n match = gridref.match(/^[A-Z]{2}\\s*[0-9]+\\s*[0-9]+$/i);\n if (!match) throw new Error('Invalid grid reference');\n\n // get numeric values of letter references, mapping A->0, B->1, C->2, etc:\n var l1 = gridref.toUpperCase().charCodeAt(0) - 'A'.charCodeAt(0);\n var l2 = gridref.toUpperCase().charCodeAt(1) - 'A'.charCodeAt(0);\n // shuffle down letters after 'I' since 'I' is not used in grid:\n if (l1 > 7) l1--;\n if (l2 > 7) l2--;\n\n // convert grid letters into 100km-square indexes from false origin (grid square SV):\n var e100km = ((l1-2)%5)*5 + (l2%5);\n var n100km = (19-Math.floor(l1/5)*5) - Math.floor(l2/5);\n\n // skip grid letters to get numeric (easting/northing) part of ref\n var en = gridref.slice(2).trim().split(/\\s+/);\n // if e/n not whitespace separated, split half way\n if (en.length == 1) en = [ en[0].slice(0, en[0].length/2), en[0].slice(en[0].length/2) ];\n\n // validation\n if (e100km<0 || e100km>6 || n100km<0 || n100km>12) throw new Error('Invalid grid reference');\n if (en.length != 2) throw new Error('Invalid grid reference');\n if (en[0].length != en[1].length) throw new Error('Invalid grid reference');\n\n // standardise to 10-digit refs (metres)\n en[0] = (en[0]+'00000').slice(0, 5);\n en[1] = (en[1]+'00000').slice(0, 5);\n\n var e = e100km + en[0];\n var n = n100km + en[1];\n\n return new OsGridRef(e, n);\n};\n\n\n/**\n * Converts ‘this’ numeric grid reference to standard OS grid reference.\n *\n * @param {number} [digits=10] - Precision of returned grid reference (10 digits = metres);\n * digits=0 will return grid reference in numeric format.\n * @returns {string} This grid reference in standard format.\n *\n * @example\n * var ref = new OsGridRef(651409, 313177).toString(); // TG 51409 13177\n */\nOsGridRef.prototype.toString = function(digits) {\n digits = (digits === undefined) ? 10 : Number(digits);\n if (isNaN(digits) || digits%2!=0 || digits>16) throw new RangeError('Invalid precision ‘'+digits+'’');\n\n var e = this.easting;\n var n = this.northing;\n if (isNaN(e) || isNaN(n)) throw new Error('Invalid grid reference');\n\n // use digits = 0 to return numeric format (in metres, allowing for decimals & for northing > 1e6)\n if (digits == 0) {\n var eInt = Math.floor(e), eDec = e - eInt;\n var nInt = Math.floor(n), nDec = n - nInt;\n var ePad = ('000000'+eInt).slice(-6) + (eDec>0 ? eDec.toFixed(3).slice(1) : '');\n var nPad = (nInt<1e6 ? ('000000'+nInt).slice(-6) : nInt) + (nDec>0 ? nDec.toFixed(3).slice(1) : '');\n return ePad + ',' + nPad;\n }\n\n // get the 100km-grid indices\n var e100k = Math.floor(e/100000), n100k = Math.floor(n/100000);\n\n if (e100k<0 || e100k>6 || n100k<0 || n100k>12) return '';\n\n // translate those into numeric equivalents of the grid letters\n var l1 = (19-n100k) - (19-n100k)%5 + Math.floor((e100k+10)/5);\n var l2 = (19-n100k)*5%25 + e100k%5;\n\n // compensate for skipped 'I' and build grid letter-pairs\n if (l1 > 7) l1++;\n if (l2 > 7) l2++;\n var letterPair = String.fromCharCode(l1+'A'.charCodeAt(0), l2+'A'.charCodeAt(0));\n\n // strip 100km-grid indices from easting & northing, and reduce precision\n e = Math.floor((e%100000)/Math.pow(10, 5-digits/2));\n n = Math.floor((n%100000)/Math.pow(10, 5-digits/2));\n\n // pad eastings & northings with leading zeros (just in case, allow up to 16-digit (mm) refs)\n e = ('00000000'+e).slice(-digits/2);\n n = ('00000000'+n).slice(-digits/2);\n\n return letterPair + ' ' + e + ' ' + n;\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = OsGridRef; // ≡ export default OsGridRef\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('IxVectorLayer',{attrs:{\"features\":_vm.features,\"vector-style\":_vm.vectorStyle,\"z-index\":1}})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./FrsCurrentFieldBorderLayer.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!./FrsCurrentFieldBorderLayer.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./FrsCurrentFieldBorderLayer.vue?vue&type=template&id=83de5aaa&scoped=true&lang=html&\"\nimport script from \"./FrsCurrentFieldBorderLayer.vue?vue&type=script&lang=js&\"\nexport * from \"./FrsCurrentFieldBorderLayer.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 \"83de5aaa\",\n null\n \n)\n\nexport default component.exports","\"use strict\"\n\nvar twoProduct = require(\"two-product\")\nvar twoSum = require(\"two-sum\")\n\nmodule.exports = scaleLinearExpansion\n\nfunction scaleLinearExpansion(e, scale) {\n var n = e.length\n if(n === 1) {\n var ts = twoProduct(e[0], scale)\n if(ts[0]) {\n return ts\n }\n return [ ts[1] ]\n }\n var g = new Array(2 * n)\n var q = [0.1, 0.1]\n var t = [0.1, 0.1]\n var count = 0\n twoProduct(e[0], scale, q)\n if(q[0]) {\n g[count++] = q[0]\n }\n for(var i=1; i} bbox extent in [west, south, east, north] order\n * @returns {Array} a square surrounding `bbox`\n * @example\n * var bbox = [-20,-20,-15,0];\n * var squared = turf.square(bbox);\n * var features = turf.featureCollection([\n * turf.bboxPolygon(bbox),\n * turf.bboxPolygon(squared)\n * ]);\n *\n * //addToMap\n * var addToMap = [features]\n */\nmodule.exports = function (bbox) {\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n\n var horizontalDistance = distance(bbox.slice(0, 2), [east, south]);\n var verticalDistance = distance(bbox.slice(0, 2), [west, north]);\n if (horizontalDistance >= verticalDistance) {\n var verticalMidpoint = (south + north) / 2;\n return [\n west,\n verticalMidpoint - ((east - west) / 2),\n east,\n verticalMidpoint + ((east - west) / 2)\n ];\n } else {\n var horizontalMidpoint = (west + east) / 2;\n return [\n horizontalMidpoint - ((north - south) / 2),\n south,\n horizontalMidpoint + ((north - south) / 2),\n north\n ];\n }\n};\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* MGRS / UTM Conversion Functions (c) Chris Veness 2014-2016 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-utm-mgrs.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-mgrs.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var Utm = require('./utm.js'); // ≡ import Utm from 'utm.js'\nif (typeof module!='undefined' && module.exports) var LatLon = require('./latlon-ellipsoidal.js'); // ≡ import LatLon from 'latlon-ellipsoidal.js'\n\n\n/**\n * Convert between Universal Transverse Mercator (UTM) coordinates and Military Grid Reference\n * System (MGRS/NATO) grid references.\n *\n * @module mgrs\n * @requires utm\n * @requires latlon-ellipsoidal\n */\n\n/* qv www.fgdc.gov/standards/projects/FGDC-standards-projects/usng/fgdc_std_011_2001_usng.pdf p10 */\n\n\n/*\n * Latitude bands C..X 8° each, covering 80°S to 84°N\n */\nMgrs.latBands = 'CDEFGHJKLMNPQRSTUVWXX'; // X is repeated for 80-84°N\n\n\n/*\n * 100km grid square column (‘e’) letters repeat every third zone\n */\nMgrs.e100kLetters = [ 'ABCDEFGH', 'JKLMNPQR', 'STUVWXYZ' ];\n\n\n/*\n * 100km grid square row (‘n’) letters repeat every other zone\n */\nMgrs.n100kLetters = [ 'ABCDEFGHJKLMNPQRSTUV', 'FGHJKLMNPQRSTUVABCDE' ];\n\n\n/**\n * Creates an Mgrs grid reference object.\n *\n * @constructor\n * @param {number} zone - 6° longitudinal zone (1..60 covering 180°W..180°E).\n * @param {string} band - 8° latitudinal band (C..X covering 80°S..84°N).\n * @param {string} e100k - First letter (E) of 100km grid square.\n * @param {string} n100k - Second letter (N) of 100km grid square.\n * @param {number} easting - Easting in metres within 100km grid square.\n * @param {number} northing - Northing in metres within 100km grid square.\n * @param {LatLon.datum} [datum=WGS84] - Datum UTM coordinate is based on.\n * @throws {Error} Invalid MGRS grid reference.\n *\n * @example\n * var mgrsRef = new Mgrs(31, 'U', 'D', 'Q', 48251, 11932); // 31U DQ 48251 11932\n */\nfunction Mgrs(zone, band, e100k, n100k, easting, northing, datum) {\n // allow instantiation without 'new'\n if (!(this instanceof Mgrs)) return new Mgrs(zone, band, e100k, n100k, easting, northing, datum);\n\n if (datum === undefined) datum = LatLon.datum.WGS84; // default if not supplied\n\n if (!(1<=zone && zone<=60)) throw new Error('Invalid MGRS grid reference (zone ‘'+zone+'’)');\n if (band.length != 1) throw new Error('Invalid MGRS grid reference (band ‘'+band+'’)');\n if (Mgrs.latBands.indexOf(band) == -1) throw new Error('Invalid MGRS grid reference (band ‘'+band+'’)');\n if (e100k.length!=1) throw new Error('Invalid MGRS grid reference (e100k ‘'+e100k+'’)');\n if (n100k.length!=1) throw new Error('Invalid MGRS grid reference (n100k ‘'+n100k+'’)');\n\n this.zone = Number(zone);\n this.band = band;\n this.e100k = e100k;\n this.n100k = n100k;\n this.easting = Number(easting);\n this.northing = Number(northing);\n this.datum = datum;\n}\n\n\n/**\n * Converts UTM coordinate to MGRS reference.\n *\n * @returns {Mgrs}\n * @throws {Error} Invalid UTM coordinate.\n *\n * @example\n * var utmCoord = new Utm(31, 'N', 448251, 5411932);\n * var mgrsRef = utmCoord.toMgrs(); // 31U DQ 48251 11932\n */\nUtm.prototype.toMgrs = function() {\n if (isNaN(this.zone + this.easting + this.northing)) throw new Error('Invalid UTM coordinate ‘'+this.toString()+'’');\n\n // MGRS zone is same as UTM zone\n var zone = this.zone;\n\n // convert UTM to lat/long to get latitude to determine band\n var latlong = this.toLatLonE();\n // grid zones are 8° tall, 0°N is 10th band\n var band = Mgrs.latBands.charAt(Math.floor(latlong.lat/8+10)); // latitude band\n\n // columns in zone 1 are A-H, zone 2 J-R, zone 3 S-Z, then repeating every 3rd zone\n var col = Math.floor(this.easting / 100e3);\n var e100k = Mgrs.e100kLetters[(zone-1)%3].charAt(col-1); // col-1 since 1*100e3 -> A (index 0), 2*100e3 -> B (index 1), etc.\n\n // rows in even zones are A-V, in odd zones are F-E\n var row = Math.floor(this.northing / 100e3) % 20;\n var n100k = Mgrs.n100kLetters[(zone-1)%2].charAt(row);\n\n // truncate easting/northing to within 100km grid square\n var easting = this.easting % 100e3;\n var northing = this.northing % 100e3;\n\n // round to nm precision\n easting = Number(easting.toFixed(6));\n northing = Number(northing.toFixed(6));\n\n return new Mgrs(zone, band, e100k, n100k, easting, northing);\n};\n\n\n/**\n * Converts MGRS grid reference to UTM coordinate.\n *\n * @returns {Utm}\n *\n * @example\n * var utmCoord = Mgrs.parse('31U DQ 448251 11932').toUtm(); // 31 N 448251 5411932\n */\nMgrs.prototype.toUtm = function() {\n var zone = this.zone;\n var band = this.band;\n var e100k = this.e100k;\n var n100k = this.n100k;\n var easting = this.easting;\n var northing = this.northing;\n\n var hemisphere = band>='N' ? 'N' : 'S';\n\n // get easting specified by e100k\n var col = Mgrs.e100kLetters[(zone-1)%3].indexOf(e100k) + 1; // index+1 since A (index 0) -> 1*100e3, B (index 1) -> 2*100e3, etc.\n var e100kNum = col * 100e3; // e100k in metres\n\n // get northing specified by n100k\n var row = Mgrs.n100kLetters[(zone-1)%2].indexOf(n100k);\n var n100kNum = row * 100e3; // n100k in metres\n\n // get latitude of (bottom of) band\n var latBand = (Mgrs.latBands.indexOf(band)-10)*8;\n\n // northing of bottom of band, extended to include entirety of bottommost 100km square\n // (100km square boundaries are aligned with 100km UTM northing intervals)\n var nBand = Math.floor(new LatLon(latBand, 0).toUtm().northing/100e3)*100e3;\n // 100km grid square row letters repeat every 2,000km north; add enough 2,000km blocks to get\n // into required band\n var n2M = 0; // northing of 2,000km block\n while (n2M + n100kNum + northing < nBand) n2M += 2000e3;\n\n return new Utm(zone, hemisphere, e100kNum+easting, n2M+n100kNum+northing, this.datum);\n};\n\n\n/**\n * Parses string representation of MGRS grid reference.\n *\n * An MGRS grid reference comprises (space-separated)\n * - grid zone designator (GZD)\n * - 100km grid square letter-pair\n * - easting\n * - northing.\n *\n * @param {string} mgrsGridRef - String representation of MGRS grid reference.\n * @returns {Mgrs} Mgrs grid reference object.\n * @throws {Error} Invalid MGRS grid reference.\n *\n * @example\n * var mgrsRef = Mgrs.parse('31U DQ 48251 11932');\n * var mgrsRef = Mgrs.parse('31UDQ4825111932');\n * // mgrsRef: { zone:31, band:'U', e100k:'D', n100k:'Q', easting:48251, northing:11932 }\n */\nMgrs.parse = function(mgrsGridRef) {\n mgrsGridRef = mgrsGridRef.trim();\n\n // check for military-style grid reference with no separators\n if (!mgrsGridRef.match(/\\s/)) {\n var en = mgrsGridRef.slice(5); // get easting/northing following zone/band/100ksq\n en = en.slice(0, en.length/2)+' '+en.slice(-en.length/2); // separate easting/northing\n mgrsGridRef = mgrsGridRef.slice(0, 3)+' '+mgrsGridRef.slice(3, 5)+' '+en; // insert spaces\n }\n\n // match separate elements (separated by whitespace)\n mgrsGridRef = mgrsGridRef.match(/\\S+/g);\n\n if (mgrsGridRef==null || mgrsGridRef.length!=4) throw new Error('Invalid MGRS grid reference ‘'+mgrsGridRef+'’');\n\n // split gzd into zone/band\n var gzd = mgrsGridRef[0];\n var zone = gzd.slice(0, 2);\n var band = gzd.slice(2, 3);\n\n // split 100km letter-pair into e/n\n var en100k = mgrsGridRef[1];\n var e100k = en100k.slice(0, 1);\n var n100k = en100k.slice(1, 2);\n\n var e = mgrsGridRef[2], n = mgrsGridRef[3];\n\n // standardise to 10-digit refs - ie metres) (but only if < 10-digit refs, to allow decimals)\n e = e.length>=5 ? e : (e+'00000').slice(0, 5);\n n = n.length>=5 ? n : (n+'00000').slice(0, 5);\n\n return new Mgrs(zone, band, e100k, n100k, e, n);\n};\n\n\n/**\n * Returns a string representation of an MGRS grid reference.\n *\n * To distinguish from civilian UTM coordinate representations, no space is included within the\n * zone/band grid zone designator.\n *\n * Components are separated by spaces: for a military-style unseparated string, use\n * Mgrs.toString().replace(/ /g, '');\n *\n * Note that MGRS grid references get truncated, not rounded (unlike UTM coordinates).\n *\n * @param {number} [digits=10] - Precision of returned grid reference (eg 4 = km, 10 = m).\n * @returns {string} This grid reference in standard format.\n * @throws {Error} Invalid precision.\n *\n * @example\n * var mgrsStr = new Mgrs(31, 'U', 'D', 'Q', 48251, 11932).toString(); // '31U DQ 48251 11932'\n */\nMgrs.prototype.toString = function(digits) {\n digits = (digits === undefined) ? 10 : Number(digits);\n if ([ 2,4,6,8,10 ].indexOf(digits) == -1) throw new Error('Invalid precision ‘'+digits+'’');\n\n var zone = ('00'+this.zone).slice(-2); // ensure leading zero\n var band = this.band;\n\n var e100k = this.e100k;\n var n100k = this.n100k;\n\n // truncate to required precision\n var eRounded = Math.floor(this.easting/Math.pow(10, 5-digits/2));\n var nRounded = Math.floor(this.northing/Math.pow(10, 5-digits/2));\n\n // ensure leading zeros\n var easting = ('00000'+eRounded).slice(-digits/2);\n var northing = ('00000'+nRounded).slice(-digits/2);\n\n return zone+band + ' ' + e100k+n100k + ' ' + easting + ' ' + northing;\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = Mgrs; // ≡ export default Mgrs\n","var random = require('geojson-random');\n\n/**\n * Generates random {@link GeoJSON} data, including {@link Point|Points} and {@link Polygon|Polygons}, for testing\n * and experimentation.\n *\n * @name random\n * @param {string} [type='point'] type of features desired: 'points' or 'polygons'\n * @param {number} [count=1] how many geometries should be generated.\n * @param {Object} options options relevant to the feature desired. Can include:\n * @param {Array} options.bbox a bounding box inside of which geometries\n * are placed. In the case of {@link Point} features, they are guaranteed to be within this bounds,\n * while {@link Polygon} features have their centroid within the bounds.\n * @param {number} [options.num_vertices=10] options.vertices the number of vertices added\n * to polygon features.\n * @param {Number} [options.max_radial_length=10] the total number of decimal\n * degrees longitude or latitude that a polygon can extent outwards to\n * from its center.\n * @returns {FeatureCollection} generated random features\n * @example\n * var points = turf.random('points', 100, {\n * bbox: [-70, 40, -60, 60]\n * });\n *\n * var polygons = turf.random('polygons', 4, {\n * bbox: [-70, 40, -60, 60]\n * });\n *\n * //addToMap\n * var addToMap = [points, polygons]\n */\nmodule.exports = function (type, count, options) {\n options = options || {};\n count = count || 1;\n switch (type) {\n case 'point':\n case 'points':\n case undefined:\n return random.point(count, options.bbox);\n case 'polygon':\n case 'polygons':\n return random.polygon(\n count,\n options.num_vertices,\n options.max_radial_length,\n options.bbox);\n default:\n throw new Error('Unknown type given: valid options are points and polygons');\n }\n};\n","/*!\n* @license GNU Affero General Public License.\n* Copyright (c) 2015, 2015 Ronny Lorenz \n* v. 1.2.0\n* https://github.com/RaumZeit/MarchingSquares.js\n*/\n\n(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define([], function() { return { isoContours : factory() }; })\n } else if (typeof module === 'object' && module.exports) {\n // Node. Does not work with strict CommonJS, but\n // only CommonJS-like environments that support module.exports,\n // like Node.\n module.exports = { isoContours : factory() };\n } else {\n // Browser globals (root is window)\n root.MarchingSquaresJS = {\n isoContours : factory(),\n isoBands : (root.MarchingSquaresJS) ? root.MarchingSquaresJS.isoBands : null\n };\n }\n}(this, function () {\n\n /*\n Compute the isocontour(s) of a scalar 2D field given\n a certain threshold by applying the Marching Squares\n Algorithm. The function returns a list of path coordinates\n */\n var defaultSettings = {\n successCallback: null,\n verbose: false\n };\n\n var settings = {};\n\n function isoContours(data, threshold, options){\n /* process options */\n options = options ? options : {};\n\n var optionKeys = Object.keys(defaultSettings);\n\n for(var i = 0; i < optionKeys.length; i++){\n var key = optionKeys[i];\n var val = options[key];\n val = ((typeof val !== 'undefined') && (val !== null)) ? val : defaultSettings[key];\n\n settings[key] = val;\n }\n\n if(settings.verbose)\n console.log(\"MarchingSquaresJS-isoContours: computing isocontour for \" + threshold);\n\n var ret = ContourGrid2Paths(computeContourGrid(data, threshold));\n\n if(typeof settings.successCallback === 'function')\n settings.successCallback(ret);\n\n return ret;\n }\n\n /*\n Thats all for the public interface, below follows the actual\n implementation\n */\n\n /*\n ################################\n Isocontour implementation below\n ################################\n */\n\n /* assume that x1 == 1 && x0 == 0 */\n function interpolateX(y, y0, y1){\n return (y - y0) / (y1 - y0);\n }\n\n /* compute the isocontour 4-bit grid */\n function computeContourGrid(data, threshold){\n var rows = data.length - 1;\n var cols = data[0].length - 1;\n var ContourGrid = { rows: rows, cols: cols, cells: [] };\n\n for(var j = 0; j < rows; ++j){\n ContourGrid.cells[j] = [];\n for(var i = 0; i < cols; ++i){\n /* compose the 4-bit corner representation */\n var cval = 0;\n\n var tl = data[j+1][i];\n var tr = data[j+1][i+1];\n var br = data[j][i+1];\n var bl = data[j][i];\n\n if(isNaN(tl) || isNaN(tr) || isNaN(br) || isNaN(bl)){\n continue;\n }\n cval |= ((tl >= threshold) ? 8 : 0);\n cval |= ((tr >= threshold) ? 4 : 0);\n cval |= ((br >= threshold) ? 2 : 0);\n cval |= ((bl >= threshold) ? 1 : 0);\n\n /* resolve ambiguity for cval == 5 || 10 via averaging */\n var flipped = false;\n if(cval === 5 || cval === 10){\n var average = (tl + tr + br + bl) / 4;\n if(cval === 5 && (average < threshold)){\n cval = 10;\n flipped = true;\n } else if(cval === 10 && (average < threshold)){\n cval = 5;\n flipped = true;\n }\n }\n\n /* add cell to ContourGrid if it contains edges */\n if(cval != 0 && cval != 15){\n var top, bottom, left, right;\n top = bottom = left = right = 0.5;\n /* interpolate edges of cell */\n if(cval === 1){\n left = 1 - interpolateX(threshold, tl, bl);\n bottom = 1 - interpolateX(threshold, br, bl);\n } else if(cval === 2){\n bottom = interpolateX(threshold, bl, br);\n right = 1 - interpolateX(threshold, tr, br);\n } else if(cval === 3){\n left = 1 - interpolateX(threshold, tl, bl);\n right = 1 - interpolateX(threshold, tr, br);\n } else if(cval === 4){\n top = interpolateX(threshold, tl, tr);\n right = interpolateX(threshold, br, tr);\n } else if(cval === 5){\n top = interpolateX(threshold, tl, tr);\n right = interpolateX(threshold, br, tr);\n bottom = 1 - interpolateX(threshold, br, bl);\n left = 1 - interpolateX(threshold, tl, bl);\n } else if(cval === 6){\n bottom = interpolateX(threshold, bl, br);\n top = interpolateX(threshold, tl, tr);\n } else if(cval === 7){\n left = 1 - interpolateX(threshold, tl, bl);\n top = interpolateX(threshold, tl, tr);\n } else if(cval === 8){\n left = interpolateX(threshold, bl, tl);\n top = 1 - interpolateX(threshold, tr, tl);\n } else if(cval === 9){\n bottom = 1 - interpolateX(threshold, br, bl);\n top = 1 - interpolateX(threshold, tr, tl);\n } else if(cval === 10){\n top = 1 - interpolateX(threshold, tr, tl);\n right = 1 - interpolateX(threshold, tr, br);\n bottom = interpolateX(threshold, bl, br);\n left = interpolateX(threshold, bl, tl);\n } else if(cval === 11){\n top = 1 - interpolateX(threshold, tr, tl);\n right = 1 - interpolateX(threshold, tr, br);\n } else if(cval === 12){\n left = interpolateX(threshold, bl, tl);\n right = interpolateX(threshold, br, tr);\n } else if(cval === 13){\n bottom = 1 - interpolateX(threshold, br, bl);\n right = interpolateX(threshold, br, tr);\n } else if(cval === 14){\n left = interpolateX(threshold, bl, tl);\n bottom = interpolateX(threshold, bl, br);\n } else {\n console.log(\"MarchingSquaresJS-isoContours: Illegal cval detected: \" + cval);\n }\n ContourGrid.cells[j][i] = {\n cval: cval,\n flipped: flipped,\n top: top,\n right: right,\n bottom: bottom,\n left: left\n };\n }\n\n }\n }\n\n return ContourGrid;\n }\n\n function isSaddle(cell){\n return cell.cval === 5 || cell.cval === 10;\n }\n\n function isTrivial(cell){\n return cell.cval === 0 || cell.cval === 15;\n }\n\n function clearCell(cell){\n if((!isTrivial(cell)) && (cell.cval !== 5) && (cell.cval !== 10)){\n cell.cval = 15;\n }\n }\n\n function getXY(cell, edge){\n if(edge === \"top\"){\n return [cell.top, 1.0];\n } else if(edge === \"bottom\"){\n return [cell.bottom, 0.0];\n } else if(edge === \"right\"){\n return [1.0, cell.right];\n } else if(edge === \"left\"){\n return [0.0, cell.left];\n }\n }\n\n function ContourGrid2Paths(grid){\n var paths = [];\n var path_idx = 0;\n var rows = grid.rows;\n var cols = grid.cols;\n var epsilon = 1e-7;\n\n grid.cells.forEach(function(g, j){\n g.forEach(function(gg, i){\n if((typeof gg !== 'undefined') && (!isSaddle(gg)) && (!isTrivial(gg))){\n var p = tracePath(grid.cells, j, i);\n var merged = false;\n /* we may try to merge paths at this point */\n if(p.info === \"mergeable\"){\n /*\n search backwards through the path array to find an entry\n that starts with where the current path ends...\n */\n var x = p.path[p.path.length - 1][0],\n y = p.path[p.path.length - 1][1];\n\n for(var k = path_idx - 1; k >= 0; k--){\n if((Math.abs(paths[k][0][0] - x) <= epsilon) && (Math.abs(paths[k][0][1] - y) <= epsilon)){\n for(var l = p.path.length - 2; l >= 0; --l){\n paths[k].unshift(p.path[l]);\n }\n merged = true;\n break;\n }\n }\n }\n if(!merged)\n paths[path_idx++] = p.path;\n }\n });\n });\n\n return paths;\n }\n\n /*\n construct consecutive line segments from starting cell by\n walking arround the enclosed area clock-wise\n */\n function tracePath(grid, j, i){\n var maxj = grid.length;\n var p = [];\n var dxContour = [0, 0, 1, 1, 0, 0, 0, 0, -1, 0, 1, 1, -1, 0, -1, 0];\n var dyContour = [0, -1, 0, 0, 1, 1, 1, 1, 0, -1, 0, 0, 0, -1, 0, 0];\n var dx, dy;\n var startEdge = [\"none\", \"left\", \"bottom\", \"left\", \"right\", \"none\", \"bottom\", \"left\", \"top\", \"top\", \"none\", \"top\", \"right\", \"right\", \"bottom\", \"none\"];\n var nextEdge = [\"none\", \"bottom\", \"right\", \"right\", \"top\", \"top\", \"top\", \"top\", \"left\", \"bottom\", \"right\", \"right\", \"left\", \"bottom\", \"left\", \"none\"];\n var edge;\n\n var startCell = grid[j][i];\n var currentCell = grid[j][i];\n\n var cval = currentCell.cval;\n var edge = startEdge[cval];\n\n var pt = getXY(currentCell, edge);\n\n /* push initial segment */\n p.push([i + pt[0], j + pt[1]]);\n edge = nextEdge[cval];\n pt = getXY(currentCell, edge);\n p.push([i + pt[0], j + pt[1]]);\n clearCell(currentCell);\n\n /* now walk arround the enclosed area in clockwise-direction */\n var k = i + dxContour[cval];\n var l = j + dyContour[cval];\n var prev_cval = cval;\n\n while((k >= 0) && (l >= 0) && (l < maxj) && ((k != i) || (l != j))){\n currentCell = grid[l][k];\n if(typeof currentCell === 'undefined'){ /* path ends here */\n //console.log(k + \" \" + l + \" is undefined, stopping path!\");\n break;\n }\n cval = currentCell.cval;\n if((cval === 0) || (cval === 15)){\n return { path: p, info: \"mergeable\" };\n }\n edge = nextEdge[cval];\n dx = dxContour[cval];\n dy = dyContour[cval];\n if((cval === 5) || (cval === 10)){\n /* select upper or lower band, depending on previous cells cval */\n if(cval === 5){\n if(currentCell.flipped){ /* this is actually a flipped case 10 */\n if(dyContour[prev_cval] === -1){\n edge = \"left\";\n dx = -1;\n dy = 0;\n } else {\n edge = \"right\";\n dx = 1;\n dy = 0;\n }\n } else { /* real case 5 */\n if(dxContour[prev_cval] === -1){\n edge = \"bottom\";\n dx = 0;\n dy = -1;\n }\n }\n } else if(cval === 10){\n if(currentCell.flipped){ /* this is actually a flipped case 5 */\n if(dxContour[prev_cval] === -1){\n edge = \"top\";\n dx = 0;\n dy = 1;\n } else {\n edge = \"bottom\";\n dx = 0;\n dy = -1;\n }\n } else { /* real case 10 */\n if(dyContour[prev_cval] === 1){\n edge = \"left\";\n dx = -1;\n dy = 0;\n }\n }\n }\n }\n pt = getXY(currentCell, edge);\n p.push([k + pt[0], l + pt[1]]);\n clearCell(currentCell);\n k += dx;\n l += dy;\n prev_cval = cval;\n }\n\n return { path: p, info: \"closed\" };\n }\n\n return isoContours;\n\n}));\n","'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('./util'),\n orientationIndex = _require.orientationIndex;\n\nvar Node = function () {\n _createClass(Node, null, [{\n key: 'buildId',\n value: function buildId(coordinates) {\n return coordinates.join(',');\n }\n }]);\n\n function Node(coordinates) {\n _classCallCheck(this, Node);\n\n this.id = Node.buildId(coordinates);\n this.coordinates = coordinates; //< {Number[]}\n this.innerEdges = []; //< {Edge[]}\n\n // We wil store to (out) edges in an CCW order as geos::planargraph::DirectedEdgeStar does\n this.outerEdges = []; //< {Edge[]}\n this.outerEdgesSorted = false; //< {Boolean} flag that stores if the outer Edges had been sorted\n }\n\n _createClass(Node, [{\n key: 'removeInnerEdge',\n value: function removeInnerEdge(edge) {\n this.innerEdges = this.innerEdges.filter(function (e) {\n return e.from.id !== edge.from.id;\n });\n }\n }, {\n key: 'removeOuterEdge',\n value: function removeOuterEdge(edge) {\n this.outerEdges = this.outerEdges.filter(function (e) {\n return e.to.id !== edge.to.id;\n });\n }\n\n /** Outer edges are stored CCW order.\n * @param {Edge} edge - Edge to add as an outerEdge.\n */\n\n }, {\n key: 'addOuterEdge',\n value: function addOuterEdge(edge) {\n this.outerEdges.push(edge);\n this.outerEdgesSorted = false;\n }\n\n /** Sorts outer edges in CCW way.\n * @private\n */\n\n }, {\n key: 'sortOuterEdges',\n value: function sortOuterEdges() {\n var _this = this;\n\n if (!this.outerEdgesSorted) {\n //this.outerEdges.sort((a, b) => a.compareTo(b));\n // Using this comparator in order to be deterministic\n this.outerEdges.sort(function (a, b) {\n var aNode = a.to,\n bNode = b.to;\n\n if (aNode.coordinates[0] - _this.coordinates[0] >= 0 && bNode.coordinates[0] - _this.coordinates[0] < 0) return 1;\n if (aNode.coordinates[0] - _this.coordinates[0] < 0 && bNode.coordinates[0] - _this.coordinates[0] >= 0) return -1;\n\n if (aNode.coordinates[0] - _this.coordinates[0] === 0 && bNode.coordinates[0] - _this.coordinates[0] === 0) {\n if (aNode.coordinates[1] - _this.coordinates[1] >= 0 || bNode.coordinates[1] - _this.coordinates[1] >= 0) return aNode.coordinates[1] - bNode.coordinates[1];\n return bNode.coordinates[1] - aNode.coordinates[1];\n }\n\n var det = orientationIndex(_this.coordinates, aNode.coordinates, bNode.coordinates);\n if (det < 0) return 1;\n if (det > 0) return -1;\n\n var d1 = Math.pow(aNode.coordinates[0] - _this.coordinates[0], 2) + Math.pow(aNode.coordinates[1] - _this.coordinates[1], 2),\n d2 = Math.pow(bNode.coordinates[0] - _this.coordinates[0], 2) + Math.pow(bNode.coordinates[1] - _this.coordinates[1], 2);\n\n return d1 - d2;\n });\n this.outerEdgesSorted = true;\n }\n }\n\n /** Retrieves outer edges.\n * They are sorted if they aren't in the CCW order.\n * @returns {Edge[]} - List of outer edges sorted in a CCW order.\n */\n\n }, {\n key: 'getOuterEdges',\n value: function getOuterEdges() {\n this.sortOuterEdges();\n return this.outerEdges;\n }\n }, {\n key: 'getOuterEdge',\n value: function getOuterEdge(i) {\n this.sortOuterEdges();\n return this.outerEdges[i];\n }\n }, {\n key: 'addInnerEdge',\n value: function addInnerEdge(edge) {\n this.innerEdges.push(edge);\n }\n }]);\n\n return Node;\n}();\n\nmodule.exports = Node;","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isNaN(val) === false) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^((?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n if (ms >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (ms >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (ms >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (ms >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n return plural(ms, d, 'day') ||\n plural(ms, h, 'hour') ||\n plural(ms, m, 'minute') ||\n plural(ms, s, 'second') ||\n ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, n, name) {\n if (ms < n) {\n return;\n }\n if (ms < n * 1.5) {\n return Math.floor(ms / n) + ' ' + name;\n }\n return Math.ceil(ms / n) + ' ' + name + 's';\n}\n","var coordEach = require('@turf/meta').coordEach;\n\n/**\n * Takes input features and flips all of their coordinates from `[x, y]` to `[y, x]`.\n *\n * @name flip\n * @param {FeatureCollection|Feature} geojson input features\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {FeatureCollection|Feature} a feature or set of features of the same type as `input` with flipped coordinates\n * @example\n * var serbia = turf.point([20.566406, 43.421008]);\n *\n * var saudiArabia = turf.flip(serbia);\n *\n * //addToMap\n * var addToMap = [serbia, saudiArabia];\n */\nmodule.exports = function (geojson, mutate) {\n if (!geojson) throw new Error('geojson is required');\n // ensure that we don't modify features in-place and changes to the\n // output do not change the previous feature, including changes to nested\n // properties.\n if (mutate === false || mutate === undefined) geojson = JSON.parse(JSON.stringify(geojson));\n\n coordEach(geojson, function (coord) {\n var x = coord[0];\n var y = coord[1];\n coord[0] = y;\n coord[1] = x;\n });\n return geojson;\n};\n","var d3 = require('d3-geo');\nvar jsts = require('jsts');\nvar meta = require('@turf/meta');\nvar center = require('@turf/center');\nvar helpers = require('@turf/helpers');\nvar turfBbox = require('@turf/bbox');\nvar projection = require('@turf/projection');\nvar toWgs84 = projection.toWgs84;\nvar feature = helpers.feature;\nvar geomEach = meta.geomEach;\nvar toMercator = projection.toMercator;\nvar featureEach = meta.featureEach;\nvar featureCollection = helpers.featureCollection;\nvar radiansToDistance = helpers.radiansToDistance;\nvar distanceToRadians = helpers.distanceToRadians;\n\n/**\n * Calculates a buffer for input features for a given radius. Units supported are miles, kilometers, and degrees.\n *\n * When using a negative radius, the resulting geometry may be invalid if\n * it's too small compared to the radius magnitude. If the input is a\n * FeatureCollection, only valid members will be returned in the output\n * FeatureCollection - i.e., the output collection may have fewer members than\n * the input, or even be empty.\n *\n * @name buffer\n * @param {FeatureCollection|Geometry|Feature} geojson input to be buffered\n * @param {number} radius distance to draw the buffer (negative values are allowed)\n * @param {string} [units=kilometers] any of the options supported by turf units\n * @param {number} [steps=64] number of steps\n * @returns {FeatureCollection|Feature|undefined} buffered features\n * @example\n * var point = turf.point([-90.548630, 14.616599]);\n * var buffered = turf.buffer(point, 500, 'miles');\n *\n * //addToMap\n * var addToMap = [point, buffered]\n */\nmodule.exports = function (geojson, radius, units, steps) {\n // validation\n if (!geojson) throw new Error('geojson is required');\n // Allow negative buffers (\"erosion\") or zero-sized buffers (\"repair geometry\")\n if (radius === undefined) throw new Error('radius is required');\n if (steps <= 0) throw new Error('steps must be greater than 0');\n\n // default params\n steps = steps || 64;\n units = units || 'kilometers';\n\n var results = [];\n switch (geojson.type) {\n case 'GeometryCollection':\n geomEach(geojson, function (geometry) {\n var buffered = buffer(geometry, radius, units, steps);\n if (buffered) results.push(buffered);\n });\n return featureCollection(results);\n case 'FeatureCollection':\n featureEach(geojson, function (feature) {\n var multiBuffered = buffer(feature, radius, units, steps);\n if (multiBuffered) {\n featureEach(multiBuffered, function (buffered) {\n if (buffered) results.push(buffered);\n });\n }\n });\n return featureCollection(results);\n }\n return buffer(geojson, radius, units, steps);\n};\n\n/**\n * Buffer single Feature/Geometry\n *\n * @private\n * @param {Feature} geojson input to be buffered\n * @param {number} radius distance to draw the buffer\n * @param {string} [units='kilometers'] any of the options supported by turf units\n * @param {number} [steps=64] number of steps\n * @returns {Feature} buffered feature\n */\nfunction buffer(geojson, radius, units, steps) {\n var properties = geojson.properties || {};\n var geometry = (geojson.type === 'Feature') ? geojson.geometry : geojson;\n\n // Geometry Types faster than jsts\n if (geometry.type === 'GeometryCollection') {\n var results = [];\n geomEach(geojson, function (geometry) {\n var buffered = buffer(geometry, radius, units, steps);\n if (buffered) results.push(buffered);\n });\n return featureCollection(results);\n }\n\n // Project GeoJSON to Transverse Mercator projection (convert to Meters)\n var projected;\n var bbox = turfBbox(geojson);\n var needsTransverseMercator = bbox[1] > 50 && bbox[3] > 50;\n\n if (needsTransverseMercator) {\n var projection = defineProjection(geometry);\n projected = {\n type: geometry.type,\n coordinates: projectCoords(geometry.coordinates, projection)\n };\n } else {\n projected = toMercator(geometry);\n }\n\n // JSTS buffer operation\n var reader = new jsts.io.GeoJSONReader();\n var geom = reader.read(projected);\n var distance = radiansToDistance(distanceToRadians(radius, units), 'meters');\n var buffered = geom.buffer(distance);\n var writer = new jsts.io.GeoJSONWriter();\n buffered = writer.write(buffered);\n\n // Detect if empty geometries\n if (coordsIsNaN(buffered.coordinates)) return undefined;\n\n // Unproject coordinates (convert to Degrees)\n var result;\n if (needsTransverseMercator) {\n result = {\n type: buffered.type,\n coordinates: unprojectCoords(buffered.coordinates, projection)\n };\n } else {\n result = toWgs84(buffered);\n }\n\n return (result.geometry) ? result : feature(result, properties);\n}\n\n/**\n * Coordinates isNaN\n *\n * @private\n * @param {Array} coords GeoJSON Coordinates\n * @returns {Boolean} if NaN exists\n */\nfunction coordsIsNaN(coords) {\n if (Array.isArray(coords[0])) return coordsIsNaN(coords[0]);\n return isNaN(coords[0]);\n}\n\n/**\n * Project coordinates to projection\n *\n * @private\n * @param {Array} coords to project\n * @param {GeoProjection} projection D3 Geo Projection\n * @returns {Array} projected coordinates\n */\nfunction projectCoords(coords, projection) {\n if (typeof coords[0] !== 'object') return projection(coords);\n return coords.map(function (coord) {\n return projectCoords(coord, projection);\n });\n}\n\n/**\n * Un-Project coordinates to projection\n *\n * @private\n * @param {Array} coords to un-project\n * @param {GeoProjection} projection D3 Geo Projection\n * @returns {Array} un-projected coordinates\n */\nfunction unprojectCoords(coords, projection) {\n if (typeof coords[0] !== 'object') return projection.invert(coords);\n return coords.map(function (coord) {\n return unprojectCoords(coord, projection);\n });\n}\n\n/**\n * Define Transverse Mercator projection\n *\n * @private\n * @param {Geometry|Feature} geojson Base projection on center of GeoJSON\n * @returns {GeoProjection} D3 Geo Transverse Mercator Projection\n */\nfunction defineProjection(geojson) {\n var coords = center(geojson).geometry.coordinates.reverse();\n var rotate = coords.map(function (coord) { return -coord; });\n var projection = d3.geoTransverseMercator()\n .center(coords)\n .rotate(rotate)\n .scale(6373000);\n\n return projection;\n}\n","var invariant = require('@turf/invariant');\nvar getCoord = invariant.getCoord;\nvar getGeom = invariant.getGeom;\n\n/**\n * Takes a triangular plane as a {@link Polygon}\n * and a {@link Point} within that triangle and returns the z-value\n * at that point. The Polygon should have properties `a`, `b`, and `c`\n * that define the values at its three corners. Alternatively, the z-values\n * of each triangle point can be provided by their respective 3rd coordinate\n * if their values are not provided as properties.\n *\n * @name planepoint\n * @param {Geometry|Feature|Array} point the Point for which a z-value will be calculated\n * @param {Geometry|Feature} triangle a Polygon feature with three vertices\n * @returns {number} the z-value for `interpolatedPoint`\n * @example\n * var point = turf.point([-75.3221, 39.529]);\n * // \"a\", \"b\", and \"c\" values represent the values of the coordinates in order.\n * var triangle = turf.polygon([[\n * [-75.1221, 39.57],\n * [-75.58, 39.18],\n * [-75.97, 39.86],\n * [-75.1221, 39.57]\n * ]], {\n * \"a\": 11,\n * \"b\": 122,\n * \"c\": 44\n * });\n *\n * var zValue = turf.planepoint(point, triangle);\n * point.properties.zValue = zValue;\n *\n * //addToMap\n * var addToMap = [triangle, point];\n */\nmodule.exports = function (point, triangle) {\n // Normalize input\n var coord = getCoord(point);\n var geom = getGeom(triangle);\n var coords = geom.coordinates;\n var outer = coords[0];\n if (outer.length < 4) throw new Error('OuterRing of a Polygon must have 4 or more Positions.');\n var properties = triangle.properties || {};\n var a = properties.a;\n var b = properties.b;\n var c = properties.c;\n\n // Planepoint\n var x = coord[0];\n var y = coord[1];\n var x1 = outer[0][0];\n var y1 = outer[0][1];\n var z1 = (a !== undefined ? a : outer[0][2]);\n var x2 = outer[1][0];\n var y2 = outer[1][1];\n var z2 = (b !== undefined ? b : outer[1][2]);\n var x3 = outer[2][0];\n var y3 = outer[2][1];\n var z3 = (c !== undefined ? c : outer[2][2]);\n var z = (z3 * (x - x1) * (y - y2) + z1 * (x - x2) * (y - y3) + z2 * (x - x3) * (y - y1) -\n z2 * (x - x1) * (y - y3) - z3 * (x - x2) * (y - y1) - z1 * (x - x3) * (y - y2)) /\n ((x - x1) * (y - y2) + (x - x2) * (y - y3) + (x - x3) * (y - y1) -\n (x - x1) * (y - y3) - (x - x2) * (y - y1) - (x - x3) * (y - y2));\n\n return z;\n};\n","\"use strict\"\n\nvar convexHull1d = require('./lib/ch1d')\nvar convexHull2d = require('./lib/ch2d')\nvar convexHullnd = require('./lib/chnd')\n\nmodule.exports = convexHull\n\nfunction convexHull(points) {\n var n = points.length\n if(n === 0) {\n return []\n } else if(n === 1) {\n return [[0]]\n }\n var d = points[0].length\n if(d === 0) {\n return []\n } else if(d === 1) {\n return convexHull1d(points)\n } else if(d === 2) {\n return convexHull2d(points)\n }\n return convexHullnd(points, d)\n}","//http://en.wikipedia.org/wiki/Delaunay_triangulation\n//https://github.com/ironwallaby/delaunay\nvar helpers = require('@turf/helpers');\nvar polygon = helpers.polygon;\nvar featurecollection = helpers.featureCollection;\n\n/**\n * Takes a set of {@link Point|points} and creates a\n * [Triangulated Irregular Network](http://en.wikipedia.org/wiki/Triangulated_irregular_network),\n * or a TIN for short, returned as a collection of Polygons. These are often used\n * for developing elevation contour maps or stepped heat visualizations.\n *\n * If an optional z-value property is provided then it is added as properties called `a`, `b`,\n * and `c` representing its value at each of the points that represent the corners of the\n * triangle.\n *\n * @name tin\n * @param {FeatureCollection} points input points\n * @param {String} [z] name of the property from which to pull z values\n * This is optional: if not given, then there will be no extra data added to the derived triangles.\n * @returns {FeatureCollection} TIN output\n * @example\n * // generate some random point data\n * var points = turf.random('points', 30, {\n * bbox: [50, 30, 70, 50]\n * });\n * // add a random property to each point between 0 and 9\n * for (var i = 0; i < points.features.length; i++) {\n * points.features[i].properties.z = ~~(Math.random() * 9);\n * }\n * var tin = turf.tin(points, 'z');\n *\n * //addToMap\n * var addToMap = [tin, points]\n * for (var i = 0; i < tin.features.length; i++) {\n * var properties = tin.features[i].properties;\n * properties.fill = '#' + properties.a + properties.b + properties.c;\n * }\n */\nmodule.exports = function (points, z) {\n if (points.type !== 'FeatureCollection') throw new Error('points must be a FeatureCollection');\n //break down points\n var isPointZ = false;\n return featurecollection(triangulate(points.features.map(function (p) {\n var point = {\n x: p.geometry.coordinates[0],\n y: p.geometry.coordinates[1]\n };\n if (z) {\n point.z = p.properties[z];\n } else if (p.geometry.coordinates.length === 3) {\n isPointZ = true;\n point.z = p.geometry.coordinates[2];\n }\n return point;\n })).map(function (triangle) {\n\n var a = [triangle.a.x, triangle.a.y];\n var b = [triangle.b.x, triangle.b.y];\n var c = [triangle.c.x, triangle.c.y];\n var properties = {};\n\n // Add z coordinates to triangle points if user passed\n // them in that way otherwise add it as a property.\n if (isPointZ) {\n a.push(triangle.a.z);\n b.push(triangle.b.z);\n c.push(triangle.c.z);\n } else {\n properties = {\n a: triangle.a.z,\n b: triangle.b.z,\n c: triangle.c.z\n };\n }\n\n return polygon([[a, b, c, a]], properties);\n\n }));\n};\n\nfunction Triangle(a, b, c) {\n this.a = a;\n this.b = b;\n this.c = c;\n\n var A = b.x - a.x,\n B = b.y - a.y,\n C = c.x - a.x,\n D = c.y - a.y,\n E = A * (a.x + b.x) + B * (a.y + b.y),\n F = C * (a.x + c.x) + D * (a.y + c.y),\n G = 2 * (A * (c.y - b.y) - B * (c.x - b.x)),\n dx, dy;\n\n // If the points of the triangle are collinear, then just find the\n // extremes and use the midpoint as the center of the circumcircle.\n this.x = (D * E - B * F) / G;\n this.y = (A * F - C * E) / G;\n dx = this.x - a.x;\n dy = this.y - a.y;\n this.r = dx * dx + dy * dy;\n}\n\nfunction byX(a, b) {\n return b.x - a.x;\n}\n\nfunction dedup(edges) {\n var j = edges.length,\n a, b, i, m, n;\n\n outer:\n while (j) {\n b = edges[--j];\n a = edges[--j];\n i = j;\n while (i) {\n n = edges[--i];\n m = edges[--i];\n if ((a === m && b === n) || (a === n && b === m)) {\n edges.splice(j, 2);\n edges.splice(i, 2);\n j -= 2;\n continue outer;\n }\n }\n }\n}\n\nfunction triangulate(vertices) {\n // Bail if there aren't enough vertices to form any triangles.\n if (vertices.length < 3)\n return [];\n\n // Ensure the vertex array is in order of descending X coordinate\n // (which is needed to ensure a subquadratic runtime), and then find\n // the bounding box around the points.\n vertices.sort(byX);\n\n var i = vertices.length - 1,\n xmin = vertices[i].x,\n xmax = vertices[0].x,\n ymin = vertices[i].y,\n ymax = ymin,\n epsilon = 1e-12;\n\n var a,\n b,\n c,\n A,\n B,\n G;\n\n while (i--) {\n if (vertices[i].y < ymin)\n ymin = vertices[i].y;\n if (vertices[i].y > ymax)\n ymax = vertices[i].y;\n }\n\n //Find a supertriangle, which is a triangle that surrounds all the\n //vertices. This is used like something of a sentinel value to remove\n //cases in the main algorithm, and is removed before we return any\n // results.\n\n // Once found, put it in the \"open\" list. (The \"open\" list is for\n // triangles who may still need to be considered; the \"closed\" list is\n // for triangles which do not.)\n var dx = xmax - xmin,\n dy = ymax - ymin,\n dmax = (dx > dy) ? dx : dy,\n xmid = (xmax + xmin) * 0.5,\n ymid = (ymax + ymin) * 0.5,\n open = [\n new Triangle({\n x: xmid - 20 * dmax,\n y: ymid - dmax,\n __sentinel: true\n }, {\n x: xmid,\n y: ymid + 20 * dmax,\n __sentinel: true\n }, {\n x: xmid + 20 * dmax,\n y: ymid - dmax,\n __sentinel: true\n }\n )],\n closed = [],\n edges = [],\n j;\n\n // Incrementally add each vertex to the mesh.\n i = vertices.length;\n while (i--) {\n // For each open triangle, check to see if the current point is\n // inside it's circumcircle. If it is, remove the triangle and add\n // it's edges to an edge list.\n edges.length = 0;\n j = open.length;\n while (j--) {\n // If this point is to the right of this triangle's circumcircle,\n // then this triangle should never get checked again. Remove it\n // from the open list, add it to the closed list, and skip.\n dx = vertices[i].x - open[j].x;\n if (dx > 0 && dx * dx > open[j].r) {\n closed.push(open[j]);\n open.splice(j, 1);\n continue;\n }\n\n // If not, skip this triangle.\n dy = vertices[i].y - open[j].y;\n if (dx * dx + dy * dy > open[j].r)\n continue;\n\n // Remove the triangle and add it's edges to the edge list.\n edges.push(\n open[j].a, open[j].b,\n open[j].b, open[j].c,\n open[j].c, open[j].a\n );\n open.splice(j, 1);\n }\n\n // Remove any doubled edges.\n dedup(edges);\n\n // Add a new triangle for each edge.\n j = edges.length;\n while (j) {\n b = edges[--j];\n a = edges[--j];\n c = vertices[i];\n // Avoid adding colinear triangles (which have error-prone\n // circumcircles)\n A = b.x - a.x;\n B = b.y - a.y;\n G = 2 * (A * (c.y - b.y) - B * (c.x - b.x));\n if (Math.abs(G) > epsilon) {\n open.push(new Triangle(a, b, c));\n }\n }\n }\n\n // Copy any remaining open triangles to the closed list, and then\n // remove any triangles that share a vertex with the supertriangle.\n Array.prototype.push.apply(closed, open);\n\n i = closed.length;\n while (i--)\n if (closed[i].a.__sentinel ||\n closed[i].b.__sentinel ||\n closed[i].c.__sentinel)\n closed.splice(i, 1);\n\n return closed;\n}\n","var meta = require('@turf/meta');\nvar clone = require('@turf/clone');\nvar center = require('@turf/center');\nvar helpers = require('@turf/helpers');\nvar centroid = require('@turf/centroid');\nvar turfBBox = require('@turf/bbox');\nvar invariant = require('@turf/invariant');\nvar rhumbBearing = require('@turf/rhumb-bearing');\nvar rhumbDistance = require('@turf/rhumb-distance');\nvar rhumbDestination = require('@turf/rhumb-destination');\nvar point = helpers.point;\nvar coordEach = meta.coordEach;\nvar featureEach = meta.featureEach;\nvar getCoord = invariant.getCoord;\nvar getCoords = invariant.getCoords;\nvar getGeomType = invariant.getGeomType;\n\n\n/**\n * Scale a GeoJSON from a given point by a factor of scaling (ex: factor=2 would make the GeoJSON 200% larger).\n * If a FeatureCollection is provided, the origin point will be calculated based on each individual Feature.\n *\n * @name transformScale\n * @param {GeoJSON} geojson GeoJSON to be scaled\n * @param {number} factor of scaling, positive or negative values greater than 0\n * @param {string|Geometry|Feature|Array} [origin=\"centroid\"] Point from which the scaling will occur (string options: sw/se/nw/ne/center/centroid)\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} scaled GeoJSON\n * @example\n * var poly = turf.polygon([[[0,29],[3.5,29],[2.5,32],[0,29]]]);\n * var scaledPoly = turf.transformScale(poly, 3);\n *\n * //addToMap\n * var addToMap = [poly, scaledPoly];\n * scaledPoly.properties = {stroke: '#F00', 'stroke-width': 4};\n */\nmodule.exports = function (geojson, factor, origin, mutate) {\n // Input validation\n if (!geojson) throw new Error('geojson required');\n if (typeof factor !== 'number' || factor === 0) throw new Error('invalid factor');\n var originIsPoint = Array.isArray(origin) || typeof origin === 'object';\n\n // Clone geojson to avoid side effects\n if (mutate !== true) geojson = clone(geojson);\n\n // Scale each Feature separately\n if (geojson.type === 'FeatureCollection' && !originIsPoint) {\n featureEach(geojson, function (feature, index) {\n geojson.features[index] = scale(feature, factor, origin);\n });\n return geojson;\n }\n // Scale Feature/Geometry\n return scale(geojson, factor, origin);\n};\n\n/**\n * Scale Feature/Geometry\n *\n * @private\n * @param {Feature|Geometry} feature GeoJSON Feature/Geometry\n * @param {number} factor of scaling, positive or negative values greater than 0\n * @param {string|Geometry|Feature|Array} [origin=\"centroid\"] Point from which the scaling will occur (string options: sw/se/nw/ne/center/centroid)\n * @returns {Feature|Geometry} scaled GeoJSON Feature/Geometry\n */\nfunction scale(feature, factor, origin) {\n // Default params\n var isPoint = getGeomType(feature) === 'Point';\n origin = defineOrigin(feature, origin);\n\n // Shortcut no-scaling\n if (factor === 1 || isPoint) return feature;\n\n // Scale each coordinate\n coordEach(feature, function (coord) {\n var originalDistance = rhumbDistance(origin, coord);\n var bearing = rhumbBearing(origin, coord);\n var newDistance = originalDistance * factor;\n var newCoord = getCoords(rhumbDestination(origin, newDistance, bearing));\n coord[0] = newCoord[0];\n coord[1] = newCoord[1];\n if (coord.length === 3) coord[2] *= factor;\n });\n\n return feature;\n}\n\n/**\n * Define Origin\n *\n * @private\n * @param {GeoJSON} geojson GeoJSON\n * @param {string|Geometry|Feature|Array} origin sw/se/nw/ne/center/centroid\n * @returns {Feature} Point origin\n */\nfunction defineOrigin(geojson, origin) {\n // Default params\n if (origin === undefined || origin === null) origin = 'centroid';\n\n // Input Geometry|Feature|Array\n if (Array.isArray(origin) || typeof origin === 'object') return getCoord(origin);\n\n // Define BBox\n var bbox = (geojson.bbox) ? geojson.bbox : turfBBox(geojson);\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n\n switch (origin) {\n case 'sw':\n case 'southwest':\n case 'westsouth':\n case 'bottomleft':\n return point([west, south]);\n case 'se':\n case 'southeast':\n case 'eastsouth':\n case 'bottomright':\n return point([east, south]);\n case 'nw':\n case 'northwest':\n case 'westnorth':\n case 'topleft':\n return point([west, north]);\n case 'ne':\n case 'northeast':\n case 'eastnorth':\n case 'topright':\n return point([east, north]);\n case 'center':\n return center(geojson);\n case undefined:\n case null:\n case 'centroid':\n return centroid(geojson);\n default:\n throw new Error('invalid origin');\n }\n}\n","\"use strict\"\n\nmodule.exports = convexHull1d\n\nfunction convexHull1d(points) {\n var lo = 0\n var hi = 0\n for(var i=1; i points[hi][0]) {\n hi = i\n }\n }\n if(lo < hi) {\n return [[lo], [hi]]\n } else if(lo > hi) {\n return [[hi], [lo]]\n } else {\n return [[lo]]\n }\n}","/**\n * Callback for coordEach\n *\n * @private\n * @callback coordEachCallback\n * @param {[number, number]} currentCoords The current coordinates being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentCoords, currentIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordEach(features, function (currentCoords, currentIndex) {\n * //=currentCoords\n * //=currentIndex\n * });\n */\nfunction coordEach(layer, callback, excludeWrapCoord) {\n var i, j, k, g, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n currentIndex = 0,\n isGeometryCollection,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n coords = geometry.coordinates;\n\n wrapShrink = (excludeWrapCoord &&\n (geometry.type === 'Polygon' || geometry.type === 'MultiPolygon')) ?\n 1 : 0;\n\n if (geometry.type === 'Point') {\n callback(coords, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'LineString' || geometry.type === 'MultiPoint') {\n for (j = 0; j < coords.length; j++) {\n callback(coords[j], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'Polygon' || geometry.type === 'MultiLineString') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n callback(coords[j][k], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'MultiPolygon') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length; k++)\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n callback(coords[j][k][l], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++)\n coordEach(geometry.geometries[j], callback, excludeWrapCoord);\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.coordEach = coordEach;\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {[number, number]} currentCoords The current coordinate being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoords, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordReduce(features, function (previousValue, currentCoords, currentIndex) {\n * //=previousValue\n * //=currentCoords\n * //=currentIndex\n * return currentCoords;\n * });\n */\nfunction coordReduce(layer, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(layer, function (currentCoords, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentCoords;\n } else {\n previousValue = callback(previousValue, currentCoords, currentIndex);\n }\n }, excludeWrapCoord);\n return previousValue;\n}\nmodule.exports.coordReduce = coordReduce;\n\n/**\n * Callback for propEach\n *\n * @private\n * @callback propEachCallback\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propEach(features, function (currentProperties, currentIndex) {\n * //=currentProperties\n * //=currentIndex\n * });\n */\nfunction propEach(layer, callback) {\n var i;\n switch (layer.type) {\n case 'FeatureCollection':\n for (i = 0; i < layer.features.length; i++) {\n callback(layer.features[i].properties, i);\n }\n break;\n case 'Feature':\n callback(layer.properties, 0);\n break;\n }\n}\nmodule.exports.propEach = propEach;\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propReduce(features, function (previousValue, currentProperties, currentIndex) {\n * //=previousValue\n * //=currentProperties\n * //=currentIndex\n * return currentProperties\n * });\n */\nfunction propReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n propEach(layer, function (currentProperties, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentProperties;\n } else {\n previousValue = callback(previousValue, currentProperties, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.propReduce = propReduce;\n\n/**\n * Callback for featureEach\n *\n * @private\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureEach(features, function (currentFeature, currentIndex) {\n * //=currentFeature\n * //=currentIndex\n * });\n */\nfunction featureEach(layer, callback) {\n if (layer.type === 'Feature') {\n callback(layer, 0);\n } else if (layer.type === 'FeatureCollection') {\n for (var i = 0; i < layer.features.length; i++) {\n callback(layer.features[i], i);\n }\n }\n}\nmodule.exports.featureEach = featureEach;\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureReduce(features, function (previousValue, currentFeature, currentIndex) {\n * //=previousValue\n * //=currentFeature\n * //=currentIndex\n * return currentFeature\n * });\n */\nfunction featureReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(layer, function (currentFeature, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentFeature;\n } else {\n previousValue = callback(previousValue, currentFeature, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.featureReduce = featureReduce;\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {Object} layer any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * var coords = turf.coordAll(features);\n * //=coords\n */\nfunction coordAll(layer) {\n var coords = [];\n coordEach(layer, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\nmodule.exports.coordAll = coordAll;\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomEach(features, function (currentGeometry, currentIndex) {\n * //=currentGeometry\n * //=currentIndex\n * });\n */\nfunction geomEach(layer, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n currentIndex = 0,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n if (geometry.type === 'Point' ||\n geometry.type === 'LineString' ||\n geometry.type === 'MultiPoint' ||\n geometry.type === 'Polygon' ||\n geometry.type === 'MultiLineString' ||\n geometry.type === 'MultiPolygon') {\n callback(geometry, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++) {\n callback(geometry.geometries[j], currentIndex);\n currentIndex++;\n }\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.geomEach = geomEach;\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentGeometry The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomReduce(features, function (previousValue, currentGeometry, currentIndex) {\n * //=previousValue\n * //=currentGeometry\n * //=currentIndex\n * return currentGeometry\n * });\n */\nfunction geomReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(layer, function (currentGeometry, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentGeometry;\n } else {\n previousValue = callback(previousValue, currentGeometry, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.geomReduce = geomReduce;\n","/**\n * Earth Radius used with the Harvesine formula and approximates using a spherical (non-ellipsoid) Earth.\n */\nvar earthRadius = 6371008.8;\n\n/**\n * Unit of measurement factors using a spherical (non-ellipsoid) earth radius.\n */\nvar factors = {\n meters: earthRadius,\n metres: earthRadius,\n millimeters: earthRadius * 1000,\n millimetres: earthRadius * 1000,\n centimeters: earthRadius * 100,\n centimetres: earthRadius * 100,\n kilometers: earthRadius / 1000,\n kilometres: earthRadius / 1000,\n miles: earthRadius / 1609.344,\n nauticalmiles: earthRadius / 1852,\n inches: earthRadius * 39.370,\n yards: earthRadius / 1.0936,\n feet: earthRadius * 3.28084,\n radians: 1,\n degrees: earthRadius / 111325,\n};\n\n/**\n * Units of measurement factors based on 1 meter.\n */\nvar unitsFactors = {\n meters: 1,\n metres: 1,\n millimeters: 1000,\n millimetres: 1000,\n centimeters: 100,\n centimetres: 100,\n kilometers: 1 / 1000,\n kilometres: 1 / 1000,\n miles: 1 / 1609.344,\n nauticalmiles: 1 / 1852,\n inches: 39.370,\n yards: 1 / 1.0936,\n feet: 3.28084,\n radians: 1 / earthRadius,\n degrees: 1 / 111325,\n};\n\n/**\n * Area of measurement factors based on 1 square meter.\n */\nvar areaFactors = {\n meters: 1,\n metres: 1,\n millimeters: 1000000,\n millimetres: 1000000,\n centimeters: 10000,\n centimetres: 10000,\n kilometers: 0.000001,\n kilometres: 0.000001,\n acres: 0.000247105,\n miles: 3.86e-7,\n yards: 1.195990046,\n feet: 10.763910417,\n inches: 1550.003100006\n};\n\n/**\n * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}.\n *\n * @name feature\n * @param {Geometry} geometry input geometry\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a GeoJSON Feature\n * @example\n * var geometry = {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 50]\n * };\n *\n * var feature = turf.feature(geometry);\n *\n * //=feature\n */\nfunction feature(geometry, properties, options) {\n // Optional Parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var bbox = options.bbox;\n var id = options.id;\n\n // Validation\n if (geometry === undefined) throw new Error('geometry is required');\n if (properties && properties.constructor !== Object) throw new Error('properties must be an Object');\n if (bbox) validateBBox(bbox);\n if (id) validateId(id);\n\n // Main\n var feat = {type: 'Feature'};\n if (id) feat.id = id;\n if (bbox) feat.bbox = bbox;\n feat.properties = properties || {};\n feat.geometry = geometry;\n return feat;\n}\n\n/**\n * Creates a GeoJSON {@link Geometry} from a Geometry string type & coordinates.\n * For GeometryCollection type use `helpers.geometryCollection`\n *\n * @name geometry\n * @param {string} type Geometry Type\n * @param {Array} coordinates Coordinates\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Geometry\n * @returns {Geometry} a GeoJSON Geometry\n * @example\n * var type = 'Point';\n * var coordinates = [110, 50];\n *\n * var geometry = turf.geometry(type, coordinates);\n *\n * //=geometry\n */\nfunction geometry(type, coordinates, options) {\n // Optional Parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var bbox = options.bbox;\n\n // Validation\n if (!type) throw new Error('type is required');\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n if (bbox) validateBBox(bbox);\n\n // Main\n var geom;\n switch (type) {\n case 'Point': geom = point(coordinates).geometry; break;\n case 'LineString': geom = lineString(coordinates).geometry; break;\n case 'Polygon': geom = polygon(coordinates).geometry; break;\n case 'MultiPoint': geom = multiPoint(coordinates).geometry; break;\n case 'MultiLineString': geom = multiLineString(coordinates).geometry; break;\n case 'MultiPolygon': geom = multiPolygon(coordinates).geometry; break;\n default: throw new Error(type + ' is invalid');\n }\n if (bbox) geom.bbox = bbox;\n return geom;\n}\n\n/**\n * Creates a {@link Point} {@link Feature} from a Position.\n *\n * @name point\n * @param {Array} coordinates longitude, latitude position (each in decimal degrees)\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a Point feature\n * @example\n * var point = turf.point([-75.343, 39.984]);\n *\n * //=point\n */\nfunction point(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n if (coordinates.length < 2) throw new Error('coordinates must be at least 2 numbers long');\n if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) throw new Error('coordinates must contain numbers');\n\n return feature({\n type: 'Point',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link Point} {@link FeatureCollection} from an Array of Point coordinates.\n *\n * @name points\n * @param {Array>} coordinates an array of Points\n * @param {Object} [properties={}] Translate these properties to each Feature\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection\n * @param {string|number} [options.id] Identifier associated with the FeatureCollection\n * @returns {FeatureCollection} Point Feature\n * @example\n * var points = turf.points([\n * [-75, 39],\n * [-80, 45],\n * [-78, 50]\n * ]);\n *\n * //=points\n */\nfunction points(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n\n return featureCollection(coordinates.map(function (coords) {\n return point(coords, properties);\n }), options);\n}\n\n/**\n * Creates a {@link Polygon} {@link Feature} from an Array of LinearRings.\n *\n * @name polygon\n * @param {Array>>} coordinates an array of LinearRings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} Polygon Feature\n * @example\n * var polygon = turf.polygon([[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]], { name: 'poly1' });\n *\n * //=polygon\n */\nfunction polygon(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n\n for (var i = 0; i < coordinates.length; i++) {\n var ring = coordinates[i];\n if (ring.length < 4) {\n throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.');\n }\n for (var j = 0; j < ring[ring.length - 1].length; j++) {\n // Check if first point of Polygon contains two numbers\n if (i === 0 && j === 0 && !isNumber(ring[0][0]) || !isNumber(ring[0][1])) throw new Error('coordinates must contain numbers');\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error('First and last Position are not equivalent.');\n }\n }\n }\n\n return feature({\n type: 'Polygon',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link Polygon} {@link FeatureCollection} from an Array of Polygon coordinates.\n *\n * @name polygons\n * @param {Array>>>} coordinates an array of Polygon coordinates\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the FeatureCollection\n * @returns {FeatureCollection} Polygon FeatureCollection\n * @example\n * var polygons = turf.polygons([\n * [[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]],\n * [[[-15, 42], [-14, 46], [-12, 41], [-17, 44], [-15, 42]]],\n * ]);\n *\n * //=polygons\n */\nfunction polygons(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n\n return featureCollection(coordinates.map(function (coords) {\n return polygon(coords, properties);\n }), options);\n}\n\n/**\n * Creates a {@link LineString} {@link Feature} from an Array of Positions.\n *\n * @name lineString\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} LineString Feature\n * @example\n * var linestring1 = turf.lineString([[-24, 63], [-23, 60], [-25, 65], [-20, 69]], {name: 'line 1'});\n * var linestring2 = turf.lineString([[-14, 43], [-13, 40], [-15, 45], [-10, 49]], {name: 'line 2'});\n *\n * //=linestring1\n * //=linestring2\n */\nfunction lineString(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n if (coordinates.length < 2) throw new Error('coordinates must be an array of two or more positions');\n // Check if first point of LineString contains two numbers\n if (!isNumber(coordinates[0][1]) || !isNumber(coordinates[0][1])) throw new Error('coordinates must contain numbers');\n\n return feature({\n type: 'LineString',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link LineString} {@link FeatureCollection} from an Array of LineString coordinates.\n *\n * @name lineStrings\n * @param {Array>} coordinates an array of LinearRings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection\n * @param {string|number} [options.id] Identifier associated with the FeatureCollection\n * @returns {FeatureCollection} LineString FeatureCollection\n * @example\n * var linestrings = turf.lineStrings([\n * [[-24, 63], [-23, 60], [-25, 65], [-20, 69]],\n * [[-14, 43], [-13, 40], [-15, 45], [-10, 49]]\n * ]);\n *\n * //=linestrings\n */\nfunction lineStrings(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n\n return featureCollection(coordinates.map(function (coords) {\n return lineString(coords, properties);\n }), options);\n}\n\n/**\n * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}.\n *\n * @name featureCollection\n * @param {Feature[]} features input features\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {FeatureCollection} FeatureCollection of Features\n * @example\n * var locationA = turf.point([-75.343, 39.984], {name: 'Location A'});\n * var locationB = turf.point([-75.833, 39.284], {name: 'Location B'});\n * var locationC = turf.point([-75.534, 39.123], {name: 'Location C'});\n *\n * var collection = turf.featureCollection([\n * locationA,\n * locationB,\n * locationC\n * ]);\n *\n * //=collection\n */\nfunction featureCollection(features, options) {\n // Optional Parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var bbox = options.bbox;\n var id = options.id;\n\n // Validation\n if (!features) throw new Error('No features passed');\n if (!Array.isArray(features)) throw new Error('features must be an Array');\n if (bbox) validateBBox(bbox);\n if (id) validateId(id);\n\n // Main\n var fc = {type: 'FeatureCollection'};\n if (id) fc.id = id;\n if (bbox) fc.bbox = bbox;\n fc.features = features;\n return fc;\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiLineString\n * @param {Array>>} coordinates an array of LineStrings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a MultiLineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiLine = turf.multiLineString([[[0,0],[10,10]]]);\n *\n * //=multiLine\n */\nfunction multiLineString(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n\n return feature({\n type: 'MultiLineString',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPoint\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a MultiPoint feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPt = turf.multiPoint([[0,0],[10,10]]);\n *\n * //=multiPt\n */\nfunction multiPoint(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n\n return feature({\n type: 'MultiPoint',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPolygon\n * @param {Array>>>} coordinates an array of Polygons\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a multipolygon feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]);\n *\n * //=multiPoly\n *\n */\nfunction multiPolygon(coordinates, properties, options) {\n if (!coordinates) throw new Error('coordinates is required');\n\n return feature({\n type: 'MultiPolygon',\n coordinates: coordinates\n }, properties, options);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name geometryCollection\n * @param {Array} geometries an array of GeoJSON Geometries\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Object} [options={}] Optional Parameters\n * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature\n * @param {string|number} [options.id] Identifier associated with the Feature\n * @returns {Feature} a GeoJSON GeometryCollection Feature\n * @example\n * var pt = {\n * \"type\": \"Point\",\n * \"coordinates\": [100, 0]\n * };\n * var line = {\n * \"type\": \"LineString\",\n * \"coordinates\": [ [101, 0], [102, 1] ]\n * };\n * var collection = turf.geometryCollection([pt, line]);\n *\n * //=collection\n */\nfunction geometryCollection(geometries, properties, options) {\n if (!geometries) throw new Error('geometries is required');\n if (!Array.isArray(geometries)) throw new Error('geometries must be an Array');\n\n return feature({\n type: 'GeometryCollection',\n geometries: geometries\n }, properties, options);\n}\n\n/**\n * Round number to precision\n *\n * @param {number} num Number\n * @param {number} [precision=0] Precision\n * @returns {number} rounded number\n * @example\n * turf.round(120.4321)\n * //=120\n *\n * turf.round(120.4321, 2)\n * //=120.43\n */\nfunction round(num, precision) {\n if (num === undefined || num === null || isNaN(num)) throw new Error('num is required');\n if (precision && !(precision >= 0)) throw new Error('precision must be a positive number');\n var multiplier = Math.pow(10, precision || 0);\n return Math.round(num * multiplier) / multiplier;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from radians to a more friendly unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name radiansToLength\n * @param {number} radians in radians across the sphere\n * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} distance\n */\nfunction radiansToLength(radians, units) {\n if (radians === undefined || radians === null) throw new Error('radians is required');\n\n if (units && typeof units !== 'string') throw new Error('units must be a string');\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error(units + ' units is invalid');\n return radians * factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into radians\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name lengthToRadians\n * @param {number} distance in real units\n * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} radians\n */\nfunction lengthToRadians(distance, units) {\n if (distance === undefined || distance === null) throw new Error('distance is required');\n\n if (units && typeof units !== 'string') throw new Error('units must be a string');\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error(units + ' units is invalid');\n return distance / factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into degrees\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, centimeters, kilometres, feet\n *\n * @name lengthToDegrees\n * @param {number} distance in real units\n * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} degrees\n */\nfunction lengthToDegrees(distance, units) {\n return radiansToDegrees(lengthToRadians(distance, units));\n}\n\n/**\n * Converts any bearing angle from the north line direction (positive clockwise)\n * and returns an angle between 0-360 degrees (positive clockwise), 0 being the north line\n *\n * @name bearingToAzimuth\n * @param {number} bearing angle, between -180 and +180 degrees\n * @returns {number} angle between 0 and 360 degrees\n */\nfunction bearingToAzimuth(bearing) {\n if (bearing === null || bearing === undefined) throw new Error('bearing is required');\n\n var angle = bearing % 360;\n if (angle < 0) angle += 360;\n return angle;\n}\n\n/**\n * Converts an angle in radians to degrees\n *\n * @name radiansToDegrees\n * @param {number} radians angle in radians\n * @returns {number} degrees between 0 and 360 degrees\n */\nfunction radiansToDegrees(radians) {\n if (radians === null || radians === undefined) throw new Error('radians is required');\n\n var degrees = radians % (2 * Math.PI);\n return degrees * 180 / Math.PI;\n}\n\n/**\n * Converts an angle in degrees to radians\n *\n * @name degreesToRadians\n * @param {number} degrees angle between 0 and 360 degrees\n * @returns {number} angle in radians\n */\nfunction degreesToRadians(degrees) {\n if (degrees === null || degrees === undefined) throw new Error('degrees is required');\n\n var radians = degrees % 360;\n return radians * Math.PI / 180;\n}\n\n/**\n * Converts a length to the requested unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @param {number} length to be converted\n * @param {string} originalUnit of the length\n * @param {string} [finalUnit='kilometers'] returned unit\n * @returns {number} the converted length\n */\nfunction convertLength(length, originalUnit, finalUnit) {\n if (length === null || length === undefined) throw new Error('length is required');\n if (!(length >= 0)) throw new Error('length must be a positive number');\n\n return radiansToLength(lengthToRadians(length, originalUnit), finalUnit || 'kilometers');\n}\n\n/**\n * Converts a area to the requested unit.\n * Valid units: kilometers, kilometres, meters, metres, centimetres, millimeters, acres, miles, yards, feet, inches\n * @param {number} area to be converted\n * @param {string} [originalUnit='meters'] of the distance\n * @param {string} [finalUnit='kilometers'] returned unit\n * @returns {number} the converted distance\n */\nfunction convertArea(area, originalUnit, finalUnit) {\n if (area === null || area === undefined) throw new Error('area is required');\n if (!(area >= 0)) throw new Error('area must be a positive number');\n\n var startFactor = areaFactors[originalUnit || 'meters'];\n if (!startFactor) throw new Error('invalid original units');\n\n var finalFactor = areaFactors[finalUnit || 'kilometers'];\n if (!finalFactor) throw new Error('invalid final units');\n\n return (area / startFactor) * finalFactor;\n}\n\n/**\n * isNumber\n *\n * @param {*} num Number to validate\n * @returns {boolean} true/false\n * @example\n * turf.isNumber(123)\n * //=true\n * turf.isNumber('foo')\n * //=false\n */\nfunction isNumber(num) {\n return !isNaN(num) && num !== null && !Array.isArray(num);\n}\n\n/**\n * isObject\n *\n * @param {*} input variable to validate\n * @returns {boolean} true/false\n * @example\n * turf.isObject({elevation: 10})\n * //=true\n * turf.isObject('foo')\n * //=false\n */\nfunction isObject(input) {\n return (!!input) && (input.constructor === Object);\n}\n\n/**\n * Validate BBox\n *\n * @private\n * @param {Array} bbox BBox to validate\n * @returns {void}\n * @throws Error if BBox is not valid\n * @example\n * validateBBox([-180, -40, 110, 50])\n * //=OK\n * validateBBox([-180, -40])\n * //=Error\n * validateBBox('Foo')\n * //=Error\n * validateBBox(5)\n * //=Error\n * validateBBox(null)\n * //=Error\n * validateBBox(undefined)\n * //=Error\n */\nfunction validateBBox(bbox) {\n if (!bbox) throw new Error('bbox is required');\n if (!Array.isArray(bbox)) throw new Error('bbox must be an Array');\n if (bbox.length !== 4 && bbox.length !== 6) throw new Error('bbox must be an Array of 4 or 6 numbers');\n bbox.forEach(function (num) {\n if (!isNumber(num)) throw new Error('bbox must only contain numbers');\n });\n}\n\n/**\n * Validate Id\n *\n * @private\n * @param {string|number} id Id to validate\n * @returns {void}\n * @throws Error if Id is not valid\n * @example\n * validateId([-180, -40, 110, 50])\n * //=Error\n * validateId([-180, -40])\n * //=Error\n * validateId('Foo')\n * //=OK\n * validateId(5)\n * //=OK\n * validateId(null)\n * //=Error\n * validateId(undefined)\n * //=Error\n */\nfunction validateId(id) {\n if (!id) throw new Error('id is required');\n if (['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');\n}\n\n// Deprecated methods\nfunction radians2degrees() {\n throw new Error('method has been renamed to `radiansToDegrees`');\n}\n\nfunction degrees2radians() {\n throw new Error('method has been renamed to `degreesToRadians`');\n}\n\nfunction distanceToDegrees() {\n throw new Error('method has been renamed to `lengthToDegrees`');\n}\n\nfunction distanceToRadians() {\n throw new Error('method has been renamed to `lengthToRadians`');\n}\n\nfunction radiansToDistance() {\n throw new Error('method has been renamed to `radiansToLength`');\n}\n\nfunction bearingToAngle() {\n throw new Error('method has been renamed to `bearingToAzimuth`');\n}\n\nfunction convertDistance() {\n throw new Error('method has been renamed to `convertLength`');\n}\n\nexport { earthRadius, factors, unitsFactors, areaFactors, feature, geometry, point, points, polygon, polygons, lineString, lineStrings, featureCollection, multiLineString, multiPoint, multiPolygon, geometryCollection, round, radiansToLength, lengthToRadians, lengthToDegrees, bearingToAzimuth, radiansToDegrees, degreesToRadians, convertLength, convertArea, isNumber, isObject, validateBBox, validateId, radians2degrees, degrees2radians, distanceToDegrees, distanceToRadians, radiansToDistance, bearingToAngle, convertDistance };\n","import { isNumber } from '@turf/helpers';\n\n/**\n * Unwrap a coordinate from a Point Feature, Geometry or a single coordinate.\n *\n * @name getCoord\n * @param {Array|Geometry|Feature} coord GeoJSON Point or an Array of numbers\n * @returns {Array} coordinates\n * @example\n * var pt = turf.point([10, 10]);\n *\n * var coord = turf.getCoord(pt);\n * //= [10, 10]\n */\nfunction getCoord(coord) {\n if (!coord) throw new Error('coord is required');\n if (coord.type === 'Feature' && coord.geometry !== null && coord.geometry.type === 'Point') return coord.geometry.coordinates;\n if (coord.type === 'Point') return coord.coordinates;\n if (Array.isArray(coord) && coord.length >= 2 && coord[0].length === undefined && coord[1].length === undefined) return coord;\n\n throw new Error('coord must be GeoJSON Point or an Array of numbers');\n}\n\n/**\n * Unwrap coordinates from a Feature, Geometry Object or an Array\n *\n * @name getCoords\n * @param {Array|Geometry|Feature} coords Feature, Geometry Object or an Array\n * @returns {Array} coordinates\n * @example\n * var poly = turf.polygon([[[119.32, -8.7], [119.55, -8.69], [119.51, -8.54], [119.32, -8.7]]]);\n *\n * var coords = turf.getCoords(poly);\n * //= [[[119.32, -8.7], [119.55, -8.69], [119.51, -8.54], [119.32, -8.7]]]\n */\nfunction getCoords(coords) {\n if (!coords) throw new Error('coords is required');\n\n // Feature\n if (coords.type === 'Feature' && coords.geometry !== null) return coords.geometry.coordinates;\n\n // Geometry\n if (coords.coordinates) return coords.coordinates;\n\n // Array of numbers\n if (Array.isArray(coords)) return coords;\n\n throw new Error('coords must be GeoJSON Feature, Geometry Object or an Array');\n}\n\n/**\n * Checks if coordinates contains a number\n *\n * @name containsNumber\n * @param {Array} coordinates GeoJSON Coordinates\n * @returns {boolean} true if Array contains a number\n */\nfunction containsNumber(coordinates) {\n if (coordinates.length > 1 && isNumber(coordinates[0]) && isNumber(coordinates[1])) {\n return true;\n }\n\n if (Array.isArray(coordinates[0]) && coordinates[0].length) {\n return containsNumber(coordinates[0]);\n }\n throw new Error('coordinates must only contain numbers');\n}\n\n/**\n * Enforce expectations about types of GeoJSON objects for Turf.\n *\n * @name geojsonType\n * @param {GeoJSON} value any GeoJSON object\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction geojsonType(value, type, name) {\n if (!type || !name) throw new Error('type and name required');\n\n if (!value || value.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + value.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link Feature} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @name featureOf\n * @param {Feature} feature a feature with an expected geometry type\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} error if value is not the expected type.\n */\nfunction featureOf(feature, type, name) {\n if (!feature) throw new Error('No feature passed');\n if (!name) throw new Error('.featureOf() requires a name');\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link FeatureCollection} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @name collectionOf\n * @param {FeatureCollection} featureCollection a FeatureCollection for which features will be judged\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction collectionOf(featureCollection, type, name) {\n if (!featureCollection) throw new Error('No featureCollection passed');\n if (!name) throw new Error('.collectionOf() requires a name');\n if (!featureCollection || featureCollection.type !== 'FeatureCollection') {\n throw new Error('Invalid input to ' + name + ', FeatureCollection required');\n }\n for (var i = 0; i < featureCollection.features.length; i++) {\n var feature = featureCollection.features[i];\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n }\n}\n\n/**\n * Get Geometry from Feature or Geometry Object\n *\n * @param {Feature|Geometry} geojson GeoJSON Feature or Geometry Object\n * @returns {Geometry|null} GeoJSON Geometry Object\n * @throws {Error} if geojson is not a Feature or Geometry Object\n * @example\n * var point = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 40]\n * }\n * }\n * var geom = turf.getGeom(point)\n * //={\"type\": \"Point\", \"coordinates\": [110, 40]}\n */\nfunction getGeom(geojson) {\n if (!geojson) throw new Error('geojson is required');\n if (geojson.geometry !== undefined) return geojson.geometry;\n if (geojson.coordinates || geojson.geometries) return geojson;\n throw new Error('geojson must be a valid Feature or Geometry Object');\n}\n\n/**\n * Get Geometry Type from Feature or Geometry Object\n *\n * @throws {Error} **DEPRECATED** in v5.0.0 in favor of getType\n */\nfunction getGeomType() {\n throw new Error('invariant.getGeomType has been deprecated in v5.0 in favor of invariant.getType');\n}\n\n/**\n * Get GeoJSON object's type, Geometry type is prioritize.\n *\n * @param {GeoJSON} geojson GeoJSON object\n * @param {string} [name=\"geojson\"] name of the variable to display in error message\n * @returns {string} GeoJSON type\n * @example\n * var point = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 40]\n * }\n * }\n * var geom = turf.getType(point)\n * //=\"Point\"\n */\nfunction getType(geojson, name) {\n if (!geojson) throw new Error((name || 'geojson') + ' is required');\n // GeoJSON Feature & GeometryCollection\n if (geojson.geometry && geojson.geometry.type) return geojson.geometry.type;\n // GeoJSON Geometry & FeatureCollection\n if (geojson.type) return geojson.type;\n throw new Error((name || 'geojson') + ' is invalid');\n}\n\nexport { getCoord, getCoords, containsNumber, geojsonType, featureOf, collectionOf, getGeom, getGeomType, getType };\n","import { feature, isObject, lineString, point } from '@turf/helpers';\n\n/**\n * Callback for coordEach\n *\n * @callback coordEachCallback\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n * @param {number} geometryIndex The current index of the Geometry being processed.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentCoord, coordIndex, featureIndex, multiFeatureIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {void}\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordEach(features, function (currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=multiFeatureIndex\n * //=geometryIndex\n * });\n */\nfunction coordEach(geojson, callback, excludeWrapCoord) {\n // Handles null Geometry -- Skips this GeoJSON\n if (geojson === null) return;\n var j, k, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n coordIndex = 0,\n isGeometryCollection,\n type = geojson.type,\n isFeatureCollection = type === 'FeatureCollection',\n isFeature = type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (var featureIndex = 0; featureIndex < stop; featureIndex++) {\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[featureIndex].geometry :\n (isFeature ? geojson.geometry : geojson));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (var geomIndex = 0; geomIndex < stopG; geomIndex++) {\n var multiFeatureIndex = 0;\n var geometryIndex = 0;\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[geomIndex] : geometryMaybeCollection;\n\n // Handles null Geometry -- Skips this geometry\n if (geometry === null) continue;\n coords = geometry.coordinates;\n var geomType = geometry.type;\n\n wrapShrink = (excludeWrapCoord && (geomType === 'Polygon' || geomType === 'MultiPolygon')) ? 1 : 0;\n\n switch (geomType) {\n case null:\n break;\n case 'Point':\n if (callback(coords, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false;\n coordIndex++;\n multiFeatureIndex++;\n break;\n case 'LineString':\n case 'MultiPoint':\n for (j = 0; j < coords.length; j++) {\n if (callback(coords[j], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false;\n coordIndex++;\n if (geomType === 'MultiPoint') multiFeatureIndex++;\n }\n if (geomType === 'LineString') multiFeatureIndex++;\n break;\n case 'Polygon':\n case 'MultiLineString':\n for (j = 0; j < coords.length; j++) {\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n if (callback(coords[j][k], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false;\n coordIndex++;\n }\n if (geomType === 'MultiLineString') multiFeatureIndex++;\n if (geomType === 'Polygon') geometryIndex++;\n }\n if (geomType === 'Polygon') multiFeatureIndex++;\n break;\n case 'MultiPolygon':\n for (j = 0; j < coords.length; j++) {\n if (geomType === 'MultiPolygon') geometryIndex = 0;\n for (k = 0; k < coords[j].length; k++) {\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n if (callback(coords[j][k][l], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false;\n coordIndex++;\n }\n geometryIndex++;\n }\n multiFeatureIndex++;\n }\n break;\n case 'GeometryCollection':\n for (j = 0; j < geometry.geometries.length; j++)\n if (coordEach(geometry.geometries[j], callback, excludeWrapCoord) === false) return false;\n break;\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n * @param {number} geometryIndex The current index of the Geometry being processed.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {FeatureCollection|Geometry|Feature} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoord, coordIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordReduce(features, function (previousValue, currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {\n * //=previousValue\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=multiFeatureIndex\n * //=geometryIndex\n * return currentCoord;\n * });\n */\nfunction coordReduce(geojson, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(geojson, function (currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {\n if (coordIndex === 0 && initialValue === undefined) previousValue = currentCoord;\n else previousValue = callback(previousValue, currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex);\n }, excludeWrapCoord);\n return previousValue;\n}\n\n/**\n * Callback for propEach\n *\n * @callback propEachCallback\n * @param {Object} currentProperties The current Properties being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {FeatureCollection|Feature} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, featureIndex)\n * @returns {void}\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propEach(features, function (currentProperties, featureIndex) {\n * //=currentProperties\n * //=featureIndex\n * });\n */\nfunction propEach(geojson, callback) {\n var i;\n switch (geojson.type) {\n case 'FeatureCollection':\n for (i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i].properties, i) === false) break;\n }\n break;\n case 'Feature':\n callback(geojson.properties, 0);\n break;\n }\n}\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current Properties being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {FeatureCollection|Feature} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propReduce(features, function (previousValue, currentProperties, featureIndex) {\n * //=previousValue\n * //=currentProperties\n * //=featureIndex\n * return currentProperties\n * });\n */\nfunction propReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n propEach(geojson, function (currentProperties, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentProperties;\n else previousValue = callback(previousValue, currentProperties, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for featureEach\n *\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex)\n * @returns {void}\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.featureEach(features, function (currentFeature, featureIndex) {\n * //=currentFeature\n * //=featureIndex\n * });\n */\nfunction featureEach(geojson, callback) {\n if (geojson.type === 'Feature') {\n callback(geojson, 0);\n } else if (geojson.type === 'FeatureCollection') {\n for (var i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i], i) === false) break;\n }\n }\n}\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.featureReduce(features, function (previousValue, currentFeature, featureIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * return currentFeature\n * });\n */\nfunction featureReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(geojson, function (currentFeature, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * var coords = turf.coordAll(features);\n * //= [[26, 37], [36, 53]]\n */\nfunction coordAll(geojson) {\n var coords = [];\n coordEach(geojson, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\n\n/**\n * Callback for geomEach\n *\n * @callback geomEachCallback\n * @param {Geometry} currentGeometry The current Geometry being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {Object} featureProperties The current Feature Properties being processed.\n * @param {Array} featureBBox The current Feature BBox being processed.\n * @param {number|string} featureId The current Feature Id being processed.\n */\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, featureIndex, featureProperties, featureBBox, featureId)\n * @returns {void}\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomEach(features, function (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {\n * //=currentGeometry\n * //=featureIndex\n * //=featureProperties\n * //=featureBBox\n * //=featureId\n * });\n */\nfunction geomEach(geojson, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n featureProperties,\n featureBBox,\n featureId,\n featureIndex = 0,\n isFeatureCollection = geojson.type === 'FeatureCollection',\n isFeature = geojson.type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[i].geometry :\n (isFeature ? geojson.geometry : geojson));\n featureProperties = (isFeatureCollection ? geojson.features[i].properties :\n (isFeature ? geojson.properties : {}));\n featureBBox = (isFeatureCollection ? geojson.features[i].bbox :\n (isFeature ? geojson.bbox : undefined));\n featureId = (isFeatureCollection ? geojson.features[i].id :\n (isFeature ? geojson.id : undefined));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n // Handle null Geometry\n if (geometry === null) {\n if (callback(null, featureIndex, featureProperties, featureBBox, featureId) === false) return false;\n continue;\n }\n switch (geometry.type) {\n case 'Point':\n case 'LineString':\n case 'MultiPoint':\n case 'Polygon':\n case 'MultiLineString':\n case 'MultiPolygon': {\n if (callback(geometry, featureIndex, featureProperties, featureBBox, featureId) === false) return false;\n break;\n }\n case 'GeometryCollection': {\n for (j = 0; j < geometry.geometries.length; j++) {\n if (callback(geometry.geometries[j], featureIndex, featureProperties, featureBBox, featureId) === false) return false;\n }\n break;\n }\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n // Only increase `featureIndex` per each feature\n featureIndex++;\n }\n}\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Geometry} currentGeometry The current Geometry being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {Object} featureProperties The current Feature Properties being processed.\n * @param {Array} featureBBox The current Feature BBox being processed.\n * @param {number|string} featureId The current Feature Id being processed.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomReduce(features, function (previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {\n * //=previousValue\n * //=currentGeometry\n * //=featureIndex\n * //=featureProperties\n * //=featureBBox\n * //=featureId\n * return currentGeometry\n * });\n */\nfunction geomReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(geojson, function (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentGeometry;\n else previousValue = callback(previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId);\n });\n return previousValue;\n}\n\n/**\n * Callback for flattenEach\n *\n * @callback flattenEachCallback\n * @param {Feature} currentFeature The current flattened feature being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n */\n\n/**\n * Iterate over flattened features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name flattenEach\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex, multiFeatureIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenEach(features, function (currentFeature, featureIndex, multiFeatureIndex) {\n * //=currentFeature\n * //=featureIndex\n * //=multiFeatureIndex\n * });\n */\nfunction flattenEach(geojson, callback) {\n geomEach(geojson, function (geometry, featureIndex, properties, bbox, id) {\n // Callback for single geometry\n var type = (geometry === null) ? null : geometry.type;\n switch (type) {\n case null:\n case 'Point':\n case 'LineString':\n case 'Polygon':\n if (callback(feature(geometry, properties, {bbox: bbox, id: id}), featureIndex, 0) === false) return false;\n return;\n }\n\n var geomType;\n\n // Callback for multi-geometry\n switch (type) {\n case 'MultiPoint':\n geomType = 'Point';\n break;\n case 'MultiLineString':\n geomType = 'LineString';\n break;\n case 'MultiPolygon':\n geomType = 'Polygon';\n break;\n }\n\n for (var multiFeatureIndex = 0; multiFeatureIndex < geometry.coordinates.length; multiFeatureIndex++) {\n var coordinate = geometry.coordinates[multiFeatureIndex];\n var geom = {\n type: geomType,\n coordinates: coordinate\n };\n if (callback(feature(geom, properties), featureIndex, multiFeatureIndex) === false) return false;\n }\n });\n}\n\n/**\n * Callback for flattenReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback flattenReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n */\n\n/**\n * Reduce flattened features in any GeoJSON object, similar to Array.reduce().\n *\n * @name flattenReduce\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex, multiFeatureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenReduce(features, function (previousValue, currentFeature, featureIndex, multiFeatureIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * //=multiFeatureIndex\n * return currentFeature\n * });\n */\nfunction flattenReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n flattenEach(geojson, function (currentFeature, featureIndex, multiFeatureIndex) {\n if (featureIndex === 0 && multiFeatureIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex, multiFeatureIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for segmentEach\n *\n * @callback segmentEachCallback\n * @param {Feature} currentSegment The current Segment being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n * @param {number} geometryIndex The current index of the Geometry being processed.\n * @param {number} segmentIndex The current index of the Segment being processed.\n * @returns {void}\n */\n\n/**\n * Iterate over 2-vertex line segment in any GeoJSON object, similar to Array.forEach()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON\n * @param {Function} callback a method that takes (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex)\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentEach(polygon, function (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {\n * //=currentSegment\n * //=featureIndex\n * //=multiFeatureIndex\n * //=geometryIndex\n * //=segmentIndex\n * });\n *\n * // Calculate the total number of segments\n * var total = 0;\n * turf.segmentEach(polygon, function () {\n * total++;\n * });\n */\nfunction segmentEach(geojson, callback) {\n flattenEach(geojson, function (feature$$1, featureIndex, multiFeatureIndex) {\n var segmentIndex = 0;\n\n // Exclude null Geometries\n if (!feature$$1.geometry) return;\n // (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n var type = feature$$1.geometry.type;\n if (type === 'Point' || type === 'MultiPoint') return;\n\n // Generate 2-vertex line segments\n var previousCoords;\n if (coordEach(feature$$1, function (currentCoord, coordIndex, featureIndexCoord, mutliPartIndexCoord, geometryIndex) {\n // Simulating a meta.coordReduce() since `reduce` operations cannot be stopped by returning `false`\n if (previousCoords === undefined) {\n previousCoords = currentCoord;\n return;\n }\n var currentSegment = lineString([previousCoords, currentCoord], feature$$1.properties);\n if (callback(currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) === false) return false;\n segmentIndex++;\n previousCoords = currentCoord;\n }) === false) return false;\n });\n}\n\n/**\n * Callback for segmentReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback segmentReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentSegment The current Segment being processed.\n * @param {number} featureIndex The current index of the Feature being processed.\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed.\n * @param {number} geometryIndex The current index of the Geometry being processed.\n * @param {number} segmentIndex The current index of the Segment being processed.\n */\n\n/**\n * Reduce 2-vertex line segment in any GeoJSON object, similar to Array.reduce()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON\n * @param {Function} callback a method that takes (previousValue, currentSegment, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentReduce(polygon, function (previousSegment, currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {\n * //= previousSegment\n * //= currentSegment\n * //= featureIndex\n * //= multiFeatureIndex\n * //= geometryIndex\n * //= segmentInex\n * return currentSegment\n * });\n *\n * // Calculate the total number of segments\n * var initialValue = 0\n * var total = turf.segmentReduce(polygon, function (previousValue) {\n * previousValue++;\n * return previousValue;\n * }, initialValue);\n */\nfunction segmentReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n var started = false;\n segmentEach(geojson, function (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {\n if (started === false && initialValue === undefined) previousValue = currentSegment;\n else previousValue = callback(previousValue, currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex);\n started = true;\n });\n return previousValue;\n}\n\n/**\n * Callback for lineEach\n *\n * @callback lineEachCallback\n * @param {Feature} currentLine The current LineString|LinearRing being processed\n * @param {number} featureIndex The current index of the Feature being processed\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed\n * @param {number} geometryIndex The current index of the Geometry being processed\n */\n\n/**\n * Iterate over line or ring coordinates in LineString, Polygon, MultiLineString, MultiPolygon Features or Geometries,\n * similar to Array.forEach.\n *\n * @name lineEach\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (currentLine, featureIndex, multiFeatureIndex, geometryIndex)\n * @example\n * var multiLine = turf.multiLineString([\n * [[26, 37], [35, 45]],\n * [[36, 53], [38, 50], [41, 55]]\n * ]);\n *\n * turf.lineEach(multiLine, function (currentLine, featureIndex, multiFeatureIndex, geometryIndex) {\n * //=currentLine\n * //=featureIndex\n * //=multiFeatureIndex\n * //=geometryIndex\n * });\n */\nfunction lineEach(geojson, callback) {\n // validation\n if (!geojson) throw new Error('geojson is required');\n\n flattenEach(geojson, function (feature$$1, featureIndex, multiFeatureIndex) {\n if (feature$$1.geometry === null) return;\n var type = feature$$1.geometry.type;\n var coords = feature$$1.geometry.coordinates;\n switch (type) {\n case 'LineString':\n if (callback(feature$$1, featureIndex, multiFeatureIndex, 0, 0) === false) return false;\n break;\n case 'Polygon':\n for (var geometryIndex = 0; geometryIndex < coords.length; geometryIndex++) {\n if (callback(lineString(coords[geometryIndex], feature$$1.properties), featureIndex, multiFeatureIndex, geometryIndex) === false) return false;\n }\n break;\n }\n });\n}\n\n/**\n * Callback for lineReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback lineReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentLine The current LineString|LinearRing being processed.\n * @param {number} featureIndex The current index of the Feature being processed\n * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed\n * @param {number} geometryIndex The current index of the Geometry being processed\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name lineReduce\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var multiPoly = turf.multiPolygon([\n * turf.polygon([[[12,48],[2,41],[24,38],[12,48]], [[9,44],[13,41],[13,45],[9,44]]]),\n * turf.polygon([[[5, 5], [0, 0], [2, 2], [4, 4], [5, 5]]])\n * ]);\n *\n * turf.lineReduce(multiPoly, function (previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex) {\n * //=previousValue\n * //=currentLine\n * //=featureIndex\n * //=multiFeatureIndex\n * //=geometryIndex\n * return currentLine\n * });\n */\nfunction lineReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n lineEach(geojson, function (currentLine, featureIndex, multiFeatureIndex, geometryIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentLine;\n else previousValue = callback(previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex);\n });\n return previousValue;\n}\n\n/**\n * Finds a particular 2-vertex LineString Segment from a GeoJSON using `@turf/meta` indexes.\n *\n * Negative indexes are permitted.\n * Point & MultiPoint will always return null.\n *\n * @param {FeatureCollection|Feature|Geometry} geojson Any GeoJSON Feature or Geometry\n * @param {Object} [options={}] Optional parameters\n * @param {number} [options.featureIndex=0] Feature Index\n * @param {number} [options.multiFeatureIndex=0] Multi-Feature Index\n * @param {number} [options.geometryIndex=0] Geometry Index\n * @param {number} [options.segmentIndex=0] Segment Index\n * @param {Object} [options.properties={}] Translate Properties to output LineString\n * @param {BBox} [options.bbox={}] Translate BBox to output LineString\n * @param {number|string} [options.id={}] Translate Id to output LineString\n * @returns {Feature} 2-vertex GeoJSON Feature LineString\n * @example\n * var multiLine = turf.multiLineString([\n * [[10, 10], [50, 30], [30, 40]],\n * [[-10, -10], [-50, -30], [-30, -40]]\n * ]);\n *\n * // First Segment (defaults are 0)\n * turf.findSegment(multiLine);\n * // => Feature>\n *\n * // First Segment of 2nd Multi Feature\n * turf.findSegment(multiLine, {multiFeatureIndex: 1});\n * // => Feature>\n *\n * // Last Segment of Last Multi Feature\n * turf.findSegment(multiLine, {multiFeatureIndex: -1, segmentIndex: -1});\n * // => Feature>\n */\nfunction findSegment(geojson, options) {\n // Optional Parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var segmentIndex = options.segmentIndex || 0;\n\n // Find FeatureIndex\n var properties = options.properties;\n var geometry;\n\n switch (geojson.type) {\n case 'FeatureCollection':\n if (featureIndex < 0) featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case 'Feature':\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case 'Point':\n case 'MultiPoint':\n return null;\n case 'LineString':\n case 'Polygon':\n case 'MultiLineString':\n case 'MultiPolygon':\n geometry = geojson;\n break;\n default:\n throw new Error('geojson is invalid');\n }\n\n // Find SegmentIndex\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case 'Point':\n case 'MultiPoint':\n return null;\n case 'LineString':\n if (segmentIndex < 0) segmentIndex = coords.length + segmentIndex - 1;\n return lineString([coords[segmentIndex], coords[segmentIndex + 1]], properties, options);\n case 'Polygon':\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (segmentIndex < 0) segmentIndex = coords[geometryIndex].length + segmentIndex - 1;\n return lineString([coords[geometryIndex][segmentIndex], coords[geometryIndex][segmentIndex + 1]], properties, options);\n case 'MultiLineString':\n if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex;\n if (segmentIndex < 0) segmentIndex = coords[multiFeatureIndex].length + segmentIndex - 1;\n return lineString([coords[multiFeatureIndex][segmentIndex], coords[multiFeatureIndex][segmentIndex + 1]], properties, options);\n case 'MultiPolygon':\n if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0) geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (segmentIndex < 0) segmentIndex = coords[multiFeatureIndex][geometryIndex].length - segmentIndex - 1;\n return lineString([coords[multiFeatureIndex][geometryIndex][segmentIndex], coords[multiFeatureIndex][geometryIndex][segmentIndex + 1]], properties, options);\n }\n throw new Error('geojson is invalid');\n}\n\n/**\n * Finds a particular Point from a GeoJSON using `@turf/meta` indexes.\n *\n * Negative indexes are permitted.\n *\n * @param {FeatureCollection|Feature|Geometry} geojson Any GeoJSON Feature or Geometry\n * @param {Object} [options={}] Optional parameters\n * @param {number} [options.featureIndex=0] Feature Index\n * @param {number} [options.multiFeatureIndex=0] Multi-Feature Index\n * @param {number} [options.geometryIndex=0] Geometry Index\n * @param {number} [options.coordIndex=0] Coord Index\n * @param {Object} [options.properties={}] Translate Properties to output Point\n * @param {BBox} [options.bbox={}] Translate BBox to output Point\n * @param {number|string} [options.id={}] Translate Id to output Point\n * @returns {Feature} 2-vertex GeoJSON Feature Point\n * @example\n * var multiLine = turf.multiLineString([\n * [[10, 10], [50, 30], [30, 40]],\n * [[-10, -10], [-50, -30], [-30, -40]]\n * ]);\n *\n * // First Segment (defaults are 0)\n * turf.findPoint(multiLine);\n * // => Feature>\n *\n * // First Segment of the 2nd Multi-Feature\n * turf.findPoint(multiLine, {multiFeatureIndex: 1});\n * // => Feature>\n *\n * // Last Segment of last Multi-Feature\n * turf.findPoint(multiLine, {multiFeatureIndex: -1, coordIndex: -1});\n * // => Feature>\n */\nfunction findPoint(geojson, options) {\n // Optional Parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var coordIndex = options.coordIndex || 0;\n\n // Find FeatureIndex\n var properties = options.properties;\n var geometry;\n\n switch (geojson.type) {\n case 'FeatureCollection':\n if (featureIndex < 0) featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case 'Feature':\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case 'Point':\n case 'MultiPoint':\n return null;\n case 'LineString':\n case 'Polygon':\n case 'MultiLineString':\n case 'MultiPolygon':\n geometry = geojson;\n break;\n default:\n throw new Error('geojson is invalid');\n }\n\n // Find Coord Index\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case 'Point':\n return point(coords, properties, options);\n case 'MultiPoint':\n if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex;\n return point(coords[multiFeatureIndex], properties, options);\n case 'LineString':\n if (coordIndex < 0) coordIndex = coords.length + coordIndex;\n return point(coords[coordIndex], properties, options);\n case 'Polygon':\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (coordIndex < 0) coordIndex = coords[geometryIndex].length + coordIndex;\n return point(coords[geometryIndex][coordIndex], properties, options);\n case 'MultiLineString':\n if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex;\n if (coordIndex < 0) coordIndex = coords[multiFeatureIndex].length + coordIndex;\n return point(coords[multiFeatureIndex][coordIndex], properties, options);\n case 'MultiPolygon':\n if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0) geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (coordIndex < 0) coordIndex = coords[multiFeatureIndex][geometryIndex].length - coordIndex;\n return point(coords[multiFeatureIndex][geometryIndex][coordIndex], properties, options);\n }\n throw new Error('geojson is invalid');\n}\n\nexport { coordEach, coordReduce, propEach, propReduce, featureEach, featureReduce, coordAll, geomEach, geomReduce, flattenEach, flattenReduce, segmentEach, segmentReduce, lineEach, lineReduce, findSegment, findPoint };\n","import {getCoords, collectionOf} from '@turf/invariant';\nimport {featureEach} from '@turf/meta';\nimport {isObject} from '@turf/helpers';\n\n/**\n * Takes a {@link Point} grid and returns a correspondent matrix {Array>}\n * of the 'property' values\n *\n * @name gridToMatrix\n * @param {FeatureCollection} grid of points\n * @param {Object} [options={}] Optional parameters\n * @param {string} [options.zProperty='elevation'] the property name in `points` from which z-values will be pulled\n * @param {boolean} [options.flip=false] returns the matrix upside-down\n * @param {boolean} [options.flags=false] flags, adding a `matrixPosition` array field ([row, column]) to its properties,\n * the grid points with coordinates on the matrix\n * @returns {Array>} matrix of property values\n * @example\n * var extent = [-70.823364, -33.553984, -70.473175, -33.302986];\n * var cellSize = 3;\n * var grid = turf.pointGrid(extent, cellSize);\n * // add a random property to each point between 0 and 60\n * for (var i = 0; i < grid.features.length; i++) {\n * grid.features[i].properties.elevation = (Math.random() * 60);\n * }\n * gridToMatrix(grid);\n * //= [\n * [ 1, 13, 10, 9, 10, 13, 18],\n * [34, 8, 5, 4, 5, 8, 13],\n * [10, 5, 2, 1, 2, 5, 4],\n * [ 0, 4, 56, 19, 1, 4, 9],\n * [10, 5, 2, 1, 2, 5, 10],\n * [57, 8, 5, 4, 5, 0, 57],\n * [ 3, 13, 10, 9, 5, 13, 18],\n * [18, 13, 10, 9, 78, 13, 18]\n * ]\n */\nexport default function gridToMatrix(grid, options) {\n // Optional parameters\n options = options || {};\n if (!isObject(options)) throw new Error('options is invalid');\n var zProperty = options.zProperty || 'elevation';\n var flip = options.flip;\n var flags = options.flags;\n\n // validation\n collectionOf(grid, 'Point', 'input must contain Points');\n\n var pointsMatrix = sortPointsByLatLng(grid, flip);\n\n var matrix = [];\n // create property matrix from sorted points\n // looping order matters here\n for (var r = 0; r < pointsMatrix.length; r++) {\n var pointRow = pointsMatrix[r];\n var row = [];\n for (var c = 0; c < pointRow.length; c++) {\n var point = pointRow[c];\n // Check if zProperty exist\n if (point.properties[zProperty]) row.push(point.properties[zProperty]);\n else row.push(0);\n // add flags\n if (flags === true) point.properties.matrixPosition = [r, c];\n }\n matrix.push(row);\n }\n\n return matrix;\n}\n\n/**\n * Sorts points by latitude and longitude, creating a 2-dimensional array of points\n *\n * @private\n * @param {FeatureCollection} points GeoJSON Point features\n * @param {boolean} [flip=false] returns the matrix upside-down\n * @returns {Array>} points ordered by latitude and longitude\n */\nfunction sortPointsByLatLng(points, flip) {\n var pointsByLatitude = {};\n\n // divide points by rows with the same latitude\n featureEach(points, function (point) {\n var lat = getCoords(point)[1];\n if (!pointsByLatitude[lat]) pointsByLatitude[lat] = [];\n pointsByLatitude[lat].push(point);\n });\n\n // sort points (with the same latitude) by longitude\n var orderedRowsByLatitude = Object.keys(pointsByLatitude).map(function (lat) {\n var row = pointsByLatitude[lat];\n var rowOrderedByLongitude = row.sort(function (a, b) {\n return getCoords(a)[0] - getCoords(b)[0];\n });\n return rowOrderedByLongitude;\n });\n\n // sort rows (of points with the same latitude) by latitude\n var pointMatrix = orderedRowsByLatitude.sort(function (a, b) {\n if (flip) return getCoords(a[0])[1] - getCoords(b[0])[1];\n else return getCoords(b[0])[1] - getCoords(a[0])[1];\n });\n\n return pointMatrix;\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('transition',[_c('i',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.show),expression:\"show\"}],staticClass:\"fa fa-close fa-lg clear-button\",style:({right: _vm.right}),attrs:{\"tabindex\":\"0\",\"role\":\"button\",\"aria-label\":\"clear\"},on:{\"click\":function($event){$event.stopPropagation();return _vm.$emit('click')}}})])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./InputClearButton.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!./InputClearButton.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./InputClearButton.vue?vue&type=template&id=451fb25d&scoped=true&lang=html&\"\nimport script from \"./InputClearButton.vue?vue&type=script&lang=js&\"\nexport * from \"./InputClearButton.vue?vue&type=script&lang=js&\"\nimport style0 from \"./InputClearButton.vue?vue&type=style&index=0&id=451fb25d&lang=scss&scoped=true&\"\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 \"451fb25d\",\n null\n \n)\n\nexport default component.exports","\"use strict\"; \"use restrict\";\n\nvar bits = require(\"bit-twiddle\")\n , UnionFind = require(\"union-find\")\n\n//Returns the dimension of a cell complex\nfunction dimension(cells) {\n var d = 0\n , max = Math.max\n for(var i=0, il=cells.length; i> 1\n , s = compareCells(cells[mid], c)\n if(s <= 0) {\n if(s === 0) {\n r = mid\n }\n lo = mid + 1\n } else if(s > 0) {\n hi = mid - 1\n }\n }\n return r\n}\nexports.findCell = findCell;\n\n//Builds an index for an n-cell. This is more general than dual, but less efficient\nfunction incidence(from_cells, to_cells) {\n var index = new Array(from_cells.length)\n for(var i=0, il=index.length; i= from_cells.length || compareCells(from_cells[idx], b) !== 0) {\n break\n }\n }\n }\n }\n return index\n}\nexports.incidence = incidence\n\n//Computes the dual of the mesh. This is basically an optimized version of buildIndex for the situation where from_cells is just the list of vertices\nfunction dual(cells, vertex_count) {\n if(!vertex_count) {\n return incidence(unique(skeleton(cells, 0)), cells, 0)\n }\n var res = new Array(vertex_count)\n for(var i=0; i>> k) & 1) {\n b.push(c[k])\n }\n }\n result.push(b)\n }\n }\n return normalize(result)\n}\nexports.explode = explode\n\n//Enumerates all of the n-cells of a cell complex\nfunction skeleton(cells, n) {\n if(n < 0) {\n return []\n }\n var result = []\n , k0 = (1<<(n+1))-1\n for(var i=0; i 0) ? cur + arr[index - 1] : cur;\n }\n\n function scaleOffsets(cur, index) {\n cur = cur * 2 * Math.PI / circle_offsets[circle_offsets.length - 1];\n var radial_scaler = Math.random();\n vertices.push([\n radial_scaler * max_radial_length * Math.sin(cur),\n radial_scaler * max_radial_length * Math.cos(cur)\n ]);\n }\n\n return collection(features);\n};\n\n\nfunction vertexToCoordinate(hub) {\n return function(cur, index) { return [cur[0] + hub[0], cur[1] + hub[1]]; };\n}\n\nfunction rnd() { return Math.random() - 0.5; }\nfunction lon() { return rnd() * 360; }\nfunction lat() { return rnd() * 180; }\n\nfunction point(coordinates) {\n return {\n type: 'Point',\n coordinates: coordinates || [lon(), lat()]\n };\n}\n\nfunction coordInBBBOX(bbox) {\n return [\n (Math.random() * (bbox[2] - bbox[0])) + bbox[0],\n (Math.random() * (bbox[3] - bbox[1])) + bbox[1]];\n}\n\nfunction pointInBBBOX() {\n return {\n type: 'Point',\n coordinates: [lon(), lat()]\n };\n}\n\nfunction polygon(coordinates) {\n return {\n type: 'Polygon',\n coordinates: coordinates\n };\n}\n\nfunction feature(geom) {\n return {\n type: 'Feature',\n geometry: geom,\n properties: {}\n };\n}\n\nfunction collection(f) {\n return {\n type: 'FeatureCollection',\n features: f\n };\n}\n","// https://en.wikipedia.org/wiki/Rhumb_line\n// http://www.movable-type.co.uk/scripts/latlong.html#rhumblines\nvar helpers = require('@turf/helpers');\nvar getCoord = require('@turf/invariant').getCoord;\nvar GeodesyLatLon = require('geodesy').LatLonSpherical;\nvar point = helpers.point;\nvar radiansToDistance = helpers.radiansToDistance;\nvar distanceToRadians = helpers.distanceToRadians;\n\n/**\n * Returns the destination {@link Point} having travelled the given distance along a Rhumb line from the\n * origin Point with the (constant) given bearing.\n *\n * @name rhumbDestination\n * @param {Geometry|Feature|Array} origin starting point\n * @param {number} distance distance from the starting point\n * @param {number} bearing constant bearing angle ranging from -180 to 180 degrees from north\n * @param {string} [units=kilometers] miles, kilometers, degrees, or radians\n * @returns {Feature} Destination point.\n * @example\n * var point = turf.point([-75.343, 39.984], {\"marker-color\": \"F00\"});\n * var distance = 50;\n * var bearing = 90;\n * var units = 'miles';\n *\n * var destination = turf.rhumbDestination(point, distance, bearing, units);\n *\n * //addToMap\n * var addToMap = [point, destination]\n * destination.properties['marker-color'] = '#00F';\n */\nmodule.exports = function (origin, distance, bearing, units) {\n // validation\n if (!origin) throw new Error('origin is required');\n if (distance === undefined || distance === null) throw new Error('distance is required');\n if (bearing === undefined || bearing === null) throw new Error('bearing is required');\n if (!(distance >= 0)) throw new Error('distance must be greater than 0');\n\n units = units || 'kilometers';\n var distanceInMeters = radiansToDistance(distanceToRadians(distance, units), 'meters');\n var coords = getCoord(origin);\n var pt = new GeodesyLatLon(coords[1], coords[0]);\n var destination = pt.rhumbDestinationPoint(distanceInMeters, bearing);\n\n // compensate the crossing of the 180th meridian (https://macwright.org/2016/09/26/the-180th-meridian.html)\n // solution from https://github.com/mapbox/mapbox-gl-js/issues/3250#issuecomment-294887678\n destination.lon += (destination.lon - coords[0] > 180) ? -360 : (coords[0] - destination.lon > 180) ? 360 : 0;\n return point([destination.lon, destination.lat]);\n};\n","'use strict';\n\nmodule.exports = lineclip;\n\nlineclip.polyline = lineclip;\nlineclip.polygon = polygonclip;\n\n\n// Cohen-Sutherland line clippign algorithm, adapted to efficiently\n// handle polylines rather than just segments\n\nfunction lineclip(points, bbox, result) {\n\n var len = points.length,\n codeA = bitCode(points[0], bbox),\n part = [],\n i, a, b, codeB, lastCode;\n\n if (!result) result = [];\n\n for (i = 1; i < len; i++) {\n a = points[i - 1];\n b = points[i];\n codeB = lastCode = bitCode(b, bbox);\n\n while (true) {\n\n if (!(codeA | codeB)) { // accept\n part.push(a);\n\n if (codeB !== lastCode) { // segment went outside\n part.push(b);\n\n if (i < len - 1) { // start a new line\n result.push(part);\n part = [];\n }\n } else if (i === len - 1) {\n part.push(b);\n }\n break;\n\n } else if (codeA & codeB) { // trivial reject\n break;\n\n } else if (codeA) { // a outside, intersect with clip edge\n a = intersect(a, b, codeA, bbox);\n codeA = bitCode(a, bbox);\n\n } else { // b outside\n b = intersect(a, b, codeB, bbox);\n codeB = bitCode(b, bbox);\n }\n }\n\n codeA = lastCode;\n }\n\n if (part.length) result.push(part);\n\n return result;\n}\n\n// Sutherland-Hodgeman polygon clipping algorithm\n\nfunction polygonclip(points, bbox) {\n\n var result, edge, prev, prevInside, i, p, inside;\n\n // clip against each side of the clip rectangle\n for (edge = 1; edge <= 8; edge *= 2) {\n result = [];\n prev = points[points.length - 1];\n prevInside = !(bitCode(prev, bbox) & edge);\n\n for (i = 0; i < points.length; i++) {\n p = points[i];\n inside = !(bitCode(p, bbox) & edge);\n\n // if segment goes through the clip window, add an intersection\n if (inside !== prevInside) result.push(intersect(prev, p, edge, bbox));\n\n if (inside) result.push(p); // add a point if it's inside\n\n prev = p;\n prevInside = inside;\n }\n\n points = result;\n\n if (!points.length) break;\n }\n\n return result;\n}\n\n// intersect a segment against one of the 4 lines that make up the bbox\n\nfunction intersect(a, b, edge, bbox) {\n return edge & 8 ? [a[0] + (b[0] - a[0]) * (bbox[3] - a[1]) / (b[1] - a[1]), bbox[3]] : // top\n edge & 4 ? [a[0] + (b[0] - a[0]) * (bbox[1] - a[1]) / (b[1] - a[1]), bbox[1]] : // bottom\n edge & 2 ? [bbox[2], a[1] + (b[1] - a[1]) * (bbox[2] - a[0]) / (b[0] - a[0])] : // right\n edge & 1 ? [bbox[0], a[1] + (b[1] - a[1]) * (bbox[0] - a[0]) / (b[0] - a[0])] : // left\n null;\n}\n\n// bit code reflects the point position relative to the bbox:\n\n// left mid right\n// top 1001 1000 1010\n// mid 0001 0000 0010\n// bottom 0101 0100 0110\n\nfunction bitCode(p, bbox) {\n var code = 0;\n\n if (p[0] < bbox[0]) code |= 1; // left\n else if (p[0] > bbox[2]) code |= 2; // right\n\n if (p[1] < bbox[1]) code |= 4; // bottom\n else if (p[1] > bbox[3]) code |= 8; // top\n\n return code;\n}\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FrsModuleRoot.vue?vue&type=style&index=0&id=7e864fa8&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FrsModuleRoot.vue?vue&type=style&index=0&id=7e864fa8&lang=scss&scoped=true&\"","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Vincenty Direct and Inverse Solution of Geodesics on the Ellipsoid (c) Chris Veness 2002-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-vincenty.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-latlon-vincenty.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var LatLon = require('./latlon-ellipsoidal.js'); // ≡ import LatLon from 'latlon-ellipsoidal.js'\n\n\n/**\n * Direct and inverse solutions of geodesics on the ellipsoid using Vincenty formulae.\n *\n * From: T Vincenty, \"Direct and Inverse Solutions of Geodesics on the Ellipsoid with application of\n * nested equations\", Survey Review, vol XXIII no 176, 1975.\n * www.ngs.noaa.gov/PUBS_LIB/inverse.pdf.\n *\n * @module latlon-vincenty\n * @extends latlon-ellipsoidal\n */\n/** @class LatLon */\n\n\n/**\n * Returns the distance between ‘this’ point and destination point along a geodesic, using Vincenty\n * inverse solution.\n *\n * Note: the datum used is of ‘this’ point; distance is on the surface of the ellipsoid (height is\n * ignored).\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns (Number} Distance in metres between points or NaN if failed to converge.\n *\n * @example\n * var p1 = new LatLon(50.06632, -5.71475);\n * var p2 = new LatLon(58.64402, -3.07009);\n * var d = p1.distanceTo(p2); // 969,954.166 m\n */\nLatLon.prototype.distanceTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n try {\n return Number(this.inverse(point).distance.toFixed(3)); // round to 1mm precision\n } catch (e) {\n return NaN; // failed to converge\n }\n};\n\n\n/**\n * Returns the initial bearing (forward azimuth) to travel along a geodesic from ‘this’ point to the\n * specified point, using Vincenty inverse solution.\n *\n * Note: the datum used is of ‘this’ point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} initial Bearing in degrees from north (0°..360°) or NaN if failed to converge.\n *\n * @example\n * var p1 = new LatLon(50.06632, -5.71475);\n * var p2 = new LatLon(58.64402, -3.07009);\n * var b1 = p1.initialBearingTo(p2); // 9.1419°\n */\nLatLon.prototype.initialBearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n try {\n return Number(this.inverse(point).initialBearing.toFixed(9)); // round to 0.00001″ precision\n } catch (e) {\n return NaN; // failed to converge\n }\n};\n\n\n/**\n * Returns the final bearing (reverse azimuth) having travelled along a geodesic from ‘this’ point\n * to the specified point, using Vincenty inverse solution.\n *\n * Note: the datum used is of ‘this’ point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} Initial bearing in degrees from north (0°..360°) or NaN if failed to converge.\n *\n * @example\n * var p1 = new LatLon(50.06632, -5.71475);\n * var p2 = new LatLon(58.64402, -3.07009);\n * var b2 = p1.finalBearingTo(p2); // 11.2972°\n */\nLatLon.prototype.finalBearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n try {\n return Number(this.inverse(point).finalBearing.toFixed(9)); // round to 0.00001″ precision\n } catch (e) {\n return NaN; // failed to converge\n }\n};\n\n\n/**\n * Returns the destination point having travelled the given distance along a geodesic given by\n * initial bearing from ‘this’ point, using Vincenty direct solution.\n *\n * Note: the datum used is of ‘this’ point; distance is on the surface of the ellipsoid (height is\n * ignored).\n *\n * @param {number} distance - Distance travelled along the geodesic in metres.\n * @param {number} initialBearing - Initial bearing in degrees from north.\n * @returns {LatLon} Destination point.\n *\n * @example\n * var p1 = new LatLon(-37.95103, 144.42487);\n * var p2 = p1.destinationPoint(54972.271, 306.86816); // 37.6528°S, 143.9265°E\n */\nLatLon.prototype.destinationPoint = function(distance, initialBearing) {\n return this.direct(Number(distance), Number(initialBearing)).point;\n};\n\n\n/**\n * Returns the final bearing (reverse azimuth) having travelled along a geodesic given by initial\n * bearing for a given distance from ‘this’ point, using Vincenty direct solution.\n *\n * Note: the datum used is of ‘this’ point; distance is on the surface of the ellipsoid (height is\n * ignored).\n *\n * @param {number} distance - Distance travelled along the geodesic in metres.\n * @param {LatLon} initialBearing - Initial bearing in degrees from north.\n * @returns {number} Final bearing in degrees from north (0°..360°).\n *\n * @example\n * var p1 = new LatLon(-37.95103, 144.42487);\n * var b2 = p1.finalBearingOn(306.86816, 54972.271); // 307.1736°\n */\nLatLon.prototype.finalBearingOn = function(distance, initialBearing) {\n return Number(this.direct(Number(distance), Number(initialBearing)).finalBearing.toFixed(9)); // round to 0.00001″ precision\n};\n\n\n/**\n * Vincenty direct calculation.\n *\n * @private\n * @param {number} distance - Distance along bearing in metres.\n * @param {number} initialBearing - Initial bearing in degrees from north.\n * @returns (Object} Object including point (destination point), finalBearing.\n * @throws {Error} If formula failed to converge.\n */\nLatLon.prototype.direct = function(distance, initialBearing) {\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var α1 = initialBearing.toRadians();\n var s = distance;\n\n var a = this.datum.ellipsoid.a, b = this.datum.ellipsoid.b, f = this.datum.ellipsoid.f;\n\n var sinα1 = Math.sin(α1);\n var cosα1 = Math.cos(α1);\n\n var tanU1 = (1-f) * Math.tan(φ1), cosU1 = 1 / Math.sqrt((1 + tanU1*tanU1)), sinU1 = tanU1 * cosU1;\n var σ1 = Math.atan2(tanU1, cosα1);\n var sinα = cosU1 * sinα1;\n var cosSqα = 1 - sinα*sinα;\n var uSq = cosSqα * (a*a - b*b) / (b*b);\n var A = 1 + uSq/16384*(4096+uSq*(-768+uSq*(320-175*uSq)));\n var B = uSq/1024 * (256+uSq*(-128+uSq*(74-47*uSq)));\n\n var cos2σM, sinσ, cosσ, Δσ;\n\n var σ = s / (b*A), σʹ, iterations = 0;\n do {\n cos2σM = Math.cos(2*σ1 + σ);\n sinσ = Math.sin(σ);\n cosσ = Math.cos(σ);\n Δσ = B*sinσ*(cos2σM+B/4*(cosσ*(-1+2*cos2σM*cos2σM)-\n B/6*cos2σM*(-3+4*sinσ*sinσ)*(-3+4*cos2σM*cos2σM)));\n σʹ = σ;\n σ = s / (b*A) + Δσ;\n } while (Math.abs(σ-σʹ) > 1e-12 && ++iterations<100);\n if (iterations >= 100) throw new Error('Formula failed to converge'); // not possible!\n\n var x = sinU1*sinσ - cosU1*cosσ*cosα1;\n var φ2 = Math.atan2(sinU1*cosσ + cosU1*sinσ*cosα1, (1-f)*Math.sqrt(sinα*sinα + x*x));\n var λ = Math.atan2(sinσ*sinα1, cosU1*cosσ - sinU1*sinσ*cosα1);\n var C = f/16*cosSqα*(4+f*(4-3*cosSqα));\n var L = λ - (1-C) * f * sinα *\n (σ + C*sinσ*(cos2σM+C*cosσ*(-1+2*cos2σM*cos2σM)));\n var λ2 = (λ1+L+3*Math.PI)%(2*Math.PI) - Math.PI; // normalise to -180..+180\n\n var α2 = Math.atan2(sinα, -x);\n α2 = (α2 + 2*Math.PI) % (2*Math.PI); // normalise to 0..360\n\n return {\n point: new LatLon(φ2.toDegrees(), λ2.toDegrees(), this.datum),\n finalBearing: α2.toDegrees(),\n iterations: iterations,\n };\n};\n\n\n/**\n * Vincenty inverse calculation.\n *\n * @private\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {Object} Object including distance, initialBearing, finalBearing.\n * @throws {Error} If λ > π or formula failed to converge.\n */\nLatLon.prototype.inverse = function(point) {\n var p1 = this, p2 = point;\n if (p1.lon == -180) p1.lon = 180;\n var φ1 = p1.lat.toRadians(), λ1 = p1.lon.toRadians();\n var φ2 = p2.lat.toRadians(), λ2 = p2.lon.toRadians();\n\n var a = this.datum.ellipsoid.a, b = this.datum.ellipsoid.b, f = this.datum.ellipsoid.f;\n\n var L = λ2 - λ1;\n var tanU1 = (1-f) * Math.tan(φ1), cosU1 = 1 / Math.sqrt((1 + tanU1*tanU1)), sinU1 = tanU1 * cosU1;\n var tanU2 = (1-f) * Math.tan(φ2), cosU2 = 1 / Math.sqrt((1 + tanU2*tanU2)), sinU2 = tanU2 * cosU2;\n\n var sinλ, cosλ, sinSqσ, sinσ=0, cosσ=0, σ=0, sinα, cosSqα=0, cos2σM=0, C;\n\n var λ = L, λʹ, iterations = 0;\n do {\n sinλ = Math.sin(λ);\n cosλ = Math.cos(λ);\n sinSqσ = (cosU2*sinλ) * (cosU2*sinλ) + (cosU1*sinU2-sinU1*cosU2*cosλ) * (cosU1*sinU2-sinU1*cosU2*cosλ);\n if (sinSqσ == 0) break; // co-incident points\n sinσ = Math.sqrt(sinSqσ);\n cosσ = sinU1*sinU2 + cosU1*cosU2*cosλ;\n σ = Math.atan2(sinσ, cosσ);\n sinα = cosU1 * cosU2 * sinλ / sinσ;\n cosSqα = 1 - sinα*sinα;\n cos2σM = (cosSqα != 0) ? (cosσ - 2*sinU1*sinU2/cosSqα) : 0; // equatorial line: cosSqα=0 (§6)\n C = f/16*cosSqα*(4+f*(4-3*cosSqα));\n λʹ = λ;\n λ = L + (1-C) * f * sinα * (σ + C*sinσ*(cos2σM+C*cosσ*(-1+2*cos2σM*cos2σM)));\n if (Math.abs(λ) > Math.PI) throw new Error('λ > π');\n } while (Math.abs(λ-λʹ) > 1e-12 && ++iterations<1000);\n if (iterations >= 1000) throw new Error('Formula failed to converge');\n\n var uSq = cosSqα * (a*a - b*b) / (b*b);\n var A = 1 + uSq/16384*(4096+uSq*(-768+uSq*(320-175*uSq)));\n var B = uSq/1024 * (256+uSq*(-128+uSq*(74-47*uSq)));\n var Δσ = B*sinσ*(cos2σM+B/4*(cosσ*(-1+2*cos2σM*cos2σM)-\n B/6*cos2σM*(-3+4*sinσ*sinσ)*(-3+4*cos2σM*cos2σM)));\n\n var s = b*A*(σ-Δσ);\n\n var α1 = Math.atan2(cosU2*sinλ, cosU1*sinU2-sinU1*cosU2*cosλ);\n var α2 = Math.atan2(cosU1*sinλ, -sinU1*cosU2+cosU1*sinU2*cosλ);\n\n α1 = (α1 + 2*Math.PI) % (2*Math.PI); // normalise to 0..360\n α2 = (α2 + 2*Math.PI) % (2*Math.PI); // normalise to 0..360\n\n return {\n distance: s,\n initialBearing: s==0 ? NaN : α1.toDegrees(),\n finalBearing: s==0 ? NaN : α2.toDegrees(),\n iterations: iterations,\n };\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n/** Extend Number object with method to convert numeric degrees to radians */\nif (Number.prototype.toRadians === undefined) {\n Number.prototype.toRadians = function() { return this * Math.PI / 180; };\n}\n\n/** Extend Number object with method to convert radians to numeric (signed) degrees */\nif (Number.prototype.toDegrees === undefined) {\n Number.prototype.toDegrees = function() { return this * 180 / Math.PI; };\n}\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = LatLon; // ≡ export default LatLon\n","var inside = require('@turf/inside');\nvar flattenEach = require('@turf/meta').flattenEach;\nvar lineIntersect = require('@turf/line-intersect');\nvar polyToLinestring = require('@turf/polygon-to-linestring');\n\n/**\n * Boolean-disjoint returns (TRUE) if the intersection of the two geometries is an empty set.\n *\n * @name booleanDisjoint\n * @param {Geometry|Feature} feature1 GeoJSON Feature or Geometry\n * @param {Geometry|Feature} feature2 GeoJSON Feature or Geometry\n * @returns {Boolean} true/false\n * @example\n * const point = turf.point([2, 2]);\n * const line = turf.lineString([[1, 1], [1, 2], [1, 3], [1, 4]]);\n *\n * turf.booleanDisjoint(line, point);\n * //=true\n */\nmodule.exports = function (feature1, feature2) {\n var boolean;\n flattenEach(feature1, function (flatten1) {\n flattenEach(feature2, function (flatten2) {\n if (boolean === false) return false;\n boolean = disjoint(flatten1.geometry, flatten2.geometry);\n });\n });\n return boolean;\n};\n\n/**\n * Disjoint operation for simple Geometries (Point/LineString/Polygon)\n *\n * @private\n * @param {Geometry} geom1 GeoJSON Geometry\n * @param {Geometry} geom2 GeoJSON Geometry\n * @returns {Boolean} true/false\n */\nfunction disjoint(geom1, geom2) {\n switch (geom1.type) {\n case 'Point':\n switch (geom2.type) {\n case 'Point':\n return !compareCoords(geom1.coordinates, geom2.coordinates);\n case 'LineString':\n return !isPointOnLine(geom2, geom1);\n case 'Polygon':\n return !inside(geom1, geom2);\n }\n /* istanbul ignore next */\n break;\n case 'LineString':\n switch (geom2.type) {\n case 'Point':\n return !isPointOnLine(geom1, geom2);\n case 'LineString':\n return !isLineOnLine(geom1, geom2);\n case 'Polygon':\n return !isLineInPoly(geom2, geom1);\n }\n /* istanbul ignore next */\n break;\n case 'Polygon':\n switch (geom2.type) {\n case 'Point':\n return !inside(geom2, geom1);\n case 'LineString':\n return !isLineInPoly(geom1, geom2);\n case 'Polygon':\n return !isPolyInPoly(geom2, geom1);\n }\n }\n}\n\n// http://stackoverflow.com/a/11908158/1979085\nfunction isPointOnLine(lineString, point) {\n for (var i = 0; i < lineString.coordinates.length - 1; i++) {\n if (isPointOnLineSegment(lineString.coordinates[i], lineString.coordinates[i + 1], point.coordinates)) {\n return true;\n }\n }\n return false;\n}\n\nfunction isLineOnLine(lineString1, lineString2) {\n var doLinesIntersect = lineIntersect(lineString1, lineString2);\n if (doLinesIntersect.features.length > 0) {\n return true;\n }\n return false;\n}\n\nfunction isLineInPoly(polygon, lineString) {\n var doLinesIntersect = lineIntersect(lineString, polyToLinestring(polygon));\n if (doLinesIntersect.features.length > 0) {\n return true;\n }\n return false;\n}\n\n/**\n * Is Polygon (geom1) in Polygon (geom2)\n * Only takes into account outer rings\n * See http://stackoverflow.com/a/4833823/1979085\n *\n * @private\n * @param {Geometry|Feature} feature1 Polygon1\n * @param {Geometry|Feature} feature2 Polygon2\n * @returns {Boolean} true/false\n */\nfunction isPolyInPoly(feature1, feature2) {\n for (var i = 0; i < feature1.coordinates[0].length; i++) {\n if (inside(feature1.coordinates[0][i], feature2)) {\n return true;\n }\n }\n for (var i2 = 0; i2 < feature2.coordinates[0].length; i2++) {\n if (inside(feature2.coordinates[0][i2], feature1)) {\n return true;\n }\n }\n return false;\n}\n\nfunction isPointOnLineSegment(LineSegmentStart, LineSegmentEnd, Point) {\n var dxc = Point[0] - LineSegmentStart[0];\n var dyc = Point[1] - LineSegmentStart[1];\n var dxl = LineSegmentEnd[0] - LineSegmentStart[0];\n var dyl = LineSegmentEnd[1] - LineSegmentStart[1];\n var cross = dxc * dyl - dyc * dxl;\n if (cross !== 0) {\n return false;\n }\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n if (dxl > 0) {\n return LineSegmentStart[0] <= Point[0] && Point[0] <= LineSegmentEnd[0];\n } else {\n return LineSegmentEnd[0] <= Point[0] && Point[0] <= LineSegmentStart[0];\n }\n } else if (dyl > 0) {\n return LineSegmentStart[1] <= Point[1] && Point[1] <= LineSegmentEnd[1];\n } else {\n return LineSegmentEnd[1] <= Point[1] && Point[1] <= LineSegmentStart[1];\n }\n}\n\n/**\n * compareCoords\n *\n * @private\n * @param {[number, number]} pair1 point [x,y]\n * @param {[number, number]} pair2 point [x,y]\n * @returns {boolean} true/false if coord pairs match\n */\nfunction compareCoords(pair1, pair2) {\n return pair1[0] === pair2[0] && pair1[1] === pair2[1];\n}\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./RedBorderPreview.vue?vue&type=style&index=0&lang=scss&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./RedBorderPreview.vue?vue&type=style&index=0&lang=scss&\"","var coordEach = require('@turf/meta').coordEach;\nvar clone = require('@turf/clone');\n\nmodule.exports = {\n toMercator: toMercator,\n toWgs84: toWgs84\n};\n\n/**\n * Converts a WGS84 GeoJSON object into Mercator (EPSG:900913) projection\n *\n * @name toMercator\n * @param {GeoJSON} geojson WGS84 GeoJSON object\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} true/false\n * @example\n * var pt = turf.point([-71,41]);\n * var converted = turf.toMercator(pt);\n *\n * //addToMap\n * var addToMap = [pt, converted];\n */\nfunction toMercator(geojson, mutate) {\n return convert(geojson, mutate, 'mercator');\n}\n\n/**\n * Converts a Mercator (EPSG:900913) GeoJSON object into WGS84 projection\n *\n * @name toWgs84\n * @param {GeoJSON} geojson Mercator GeoJSON object\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} true/false\n * @example\n * var pt = turf.point([-7903683.846322424, 5012341.663847514]);\n * var converted = turf.toWgs84(pt);\n *\n * //addToMap\n * var addToMap = [pt, converted];\n */\nfunction toWgs84(geojson, mutate) {\n return convert(geojson, mutate, 'wgs84');\n}\n\n\n/**\n * Converts a GeoJSON coordinates to the defined `projection`\n *\n * @private\n * @param {GeoJSON} geojson GeoJSON Feature or Geometry\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @param {string} projection defines the projection system to convert the coordinates to\n * @returns {GeoJSON} true/false\n */\nfunction convert(geojson, mutate, projection) {\n if (!geojson) throw new Error('geojson is required');\n\n if (mutate !== true) geojson = clone(geojson);\n\n coordEach(geojson, function (coord) {\n var newCoord = (projection === 'mercator') ? convertToMercator(coord) : convertToWgs84(coord);\n coord[0] = newCoord[0];\n coord[1] = newCoord[1];\n });\n\n return geojson;\n}\n\n/**\n * Convert lon/lat values to 900913 x/y.\n * (from https://github.com/mapbox/sphericalmercator)\n *\n * @private\n * @param {Array} lonLat WGS84 point\n * @returns {Array} Mercator [x, y] point\n */\nfunction convertToMercator(lonLat) {\n var D2R = Math.PI / 180,\n // 900913 properties\n A = 6378137.0,\n MAXEXTENT = 20037508.342789244;\n\n // compensate longitudes passing the 180th meridian\n // from https://github.com/proj4js/proj4js/blob/master/lib/common/adjust_lon.js\n var adjusted = (Math.abs(lonLat[0]) <= 180) ? lonLat[0] : (lonLat[0] - (sign(lonLat[0]) * 360));\n var xy = [\n A * adjusted * D2R,\n A * Math.log(Math.tan((Math.PI * 0.25) + (0.5 * lonLat[1] * D2R)))\n ];\n\n // if xy value is beyond maxextent (e.g. poles), return maxextent\n if (xy[0] > MAXEXTENT) xy[0] = MAXEXTENT;\n if (xy[0] < -MAXEXTENT) xy[0] = -MAXEXTENT;\n if (xy[1] > MAXEXTENT) xy[1] = MAXEXTENT;\n if (xy[1] < -MAXEXTENT) xy[1] = -MAXEXTENT;\n\n return xy;\n}\n\n/**\n * Convert 900913 x/y values to lon/lat.\n * (from https://github.com/mapbox/sphericalmercator)\n *\n * @private\n * @param {Array} xy Mercator [x, y] point\n * @returns {Array} WGS84 [lon, lat] point\n */\nfunction convertToWgs84(xy) {\n // 900913 properties.\n var R2D = 180 / Math.PI,\n A = 6378137.0;\n\n return [\n (xy[0] * R2D / A),\n ((Math.PI * 0.5) - 2.0 * Math.atan(Math.exp(-xy[1] / A))) * R2D\n ];\n}\n\n/**\n * Returns the sign of the input, or zero\n *\n * @private\n * @param {number} x input\n * @returns {number} -1|0|1 output\n */\nfunction sign(x) {\n return (x < 0) ? -1 : (x > 0) ? 1 : 0;\n}\n","exports = module.exports = typeof Object.keys === 'function'\n ? Object.keys : shim;\n\nexports.shim = shim;\nfunction shim (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n}\n","var destination = require('@turf/destination');\nvar polygon = require('@turf/helpers').polygon;\n\n/**\n * Takes a {@link Point} and calculates the circle polygon given a radius in degrees, radians, miles, or kilometers; and steps for precision.\n *\n * @name circle\n * @param {Feature|number[]} center center point\n * @param {number} radius radius of the circle\n * @param {number} [steps=64] number of steps\n * @param {string} [units=kilometers] miles, kilometers, degrees, or radians\n * @param {Object} [properties={}] properties\n * @returns {Feature} circle polygon\n * @example\n * var center = [-75.343, 39.984];\n * var radius = 5;\n * var steps = 10;\n * var units = 'kilometers';\n * var properties = {foo: 'bar'};\n *\n * var circle = turf.circle(center, radius, steps, units, properties);\n *\n * //addToMap\n * var addToMap = [turf.point(center), circle]\n */\nmodule.exports = function (center, radius, steps, units, properties) {\n // validation\n if (!center) throw new Error('center is required');\n if (!radius) throw new Error('radius is required');\n\n // default params\n steps = steps || 64;\n properties = properties || center.properties || {};\n\n var coordinates = [];\n for (var i = 0; i < steps; i++) {\n coordinates.push(destination(center, radius, i * 360 / steps, units).geometry.coordinates);\n }\n coordinates.push(coordinates[0]);\n\n return polygon([coordinates], properties);\n};\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ListCard.vue?vue&type=style&index=0&id=234b201c&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ListCard.vue?vue&type=style&index=0&id=234b201c&lang=scss&scoped=true&\"","/**\n * This is the web browser implementation of `debug()`.\n *\n * Expose `debug()` as the module.\n */\n\nexports = module.exports = require('./debug');\nexports.log = log;\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = 'undefined' != typeof chrome\n && 'undefined' != typeof chrome.storage\n ? chrome.storage.local\n : localstorage();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n 'lightseagreen',\n 'forestgreen',\n 'goldenrod',\n 'dodgerblue',\n 'darkorchid',\n 'crimson'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\nfunction useColors() {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (typeof window !== 'undefined' && window.process && window.process.type === 'renderer') {\n return true;\n }\n\n // is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n // is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n // is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n // double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nexports.formatters.j = function(v) {\n try {\n return JSON.stringify(v);\n } catch (err) {\n return '[UnexpectedJSONParseError]: ' + err.message;\n }\n};\n\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n var useColors = this.useColors;\n\n args[0] = (useColors ? '%c' : '')\n + this.namespace\n + (useColors ? ' %c' : ' ')\n + args[0]\n + (useColors ? '%c ' : ' ')\n + '+' + exports.humanize(this.diff);\n\n if (!useColors) return;\n\n var c = 'color: ' + this.color;\n args.splice(1, 0, c, 'color: inherit')\n\n // the final \"%c\" is somewhat tricky, because there could be other\n // arguments passed either before or after the %c, so we need to\n // figure out the correct index to insert the CSS into\n var index = 0;\n var lastC = 0;\n args[0].replace(/%[a-zA-Z%]/g, function(match) {\n if ('%%' === match) return;\n index++;\n if ('%c' === match) {\n // we only are interested in the *last* %c\n // (the user may have provided their own)\n lastC = index;\n }\n });\n\n args.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.log()` when available.\n * No-op when `console.log` is not a \"function\".\n *\n * @api public\n */\n\nfunction log() {\n // this hackery is required for IE8/9, where\n // the `console.log` function doesn't have 'apply'\n return 'object' === typeof console\n && console.log\n && Function.prototype.apply.call(console.log, console, arguments);\n}\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\n\nfunction save(namespaces) {\n try {\n if (null == namespaces) {\n exports.storage.removeItem('debug');\n } else {\n exports.storage.debug = namespaces;\n }\n } catch(e) {}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\n\nfunction load() {\n var r;\n try {\n r = exports.storage.debug;\n } catch(e) {}\n\n // If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n if (!r && typeof process !== 'undefined' && 'env' in process) {\n r = process.env.DEBUG;\n }\n\n return r;\n}\n\n/**\n * Enable namespaces listed in `localStorage.debug` initially.\n */\n\nexports.enable(load());\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n try {\n return window.localStorage;\n } catch (e) {}\n}\n","var meta = require('@turf/meta');\nvar helpers = require('@turf/helpers');\nvar point = helpers.point;\nvar coordEach = meta.coordEach;\nvar featureEach = meta.featureEach;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a feature or set of features and returns all positions as {@link Point|points}.\n *\n * @name explode\n * @param {FeatureCollection|Feature} geojson input features\n * @returns {FeatureCollection} points representing the exploded input features\n * @throws {Error} if it encounters an unknown geometry type\n * @example\n * var polygon = turf.polygon([[[-81, 41], [-88, 36], [-84, 31], [-80, 33], [-77, 39], [-81, 41]]]);\n *\n * var explode = turf.explode(polygon);\n *\n * //addToMap\n * var addToMap = [polygon, explode]\n */\nmodule.exports = function (geojson) {\n var points = [];\n if (geojson.type === 'FeatureCollection') {\n featureEach(geojson, function (feature) {\n coordEach(feature, function (coord) {\n points.push(point(coord, feature.properties));\n });\n });\n } else {\n coordEach(geojson, function (coord) {\n points.push(point(coord, geojson.properties));\n });\n }\n return featureCollection(points);\n};\n","// Computes the bounding box of the specified hash of GeoJSON objects.\nexport default function(objects) {\n var x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n function boundGeometry(geometry) {\n if (geometry != null && boundGeometryType.hasOwnProperty(geometry.type)) boundGeometryType[geometry.type](geometry);\n }\n\n var boundGeometryType = {\n GeometryCollection: function(o) { o.geometries.forEach(boundGeometry); },\n Point: function(o) { boundPoint(o.coordinates); },\n MultiPoint: function(o) { o.coordinates.forEach(boundPoint); },\n LineString: function(o) { boundLine(o.arcs); },\n MultiLineString: function(o) { o.arcs.forEach(boundLine); },\n Polygon: function(o) { o.arcs.forEach(boundLine); },\n MultiPolygon: function(o) { o.arcs.forEach(boundMultiLine); }\n };\n\n function boundPoint(coordinates) {\n var x = coordinates[0],\n y = coordinates[1];\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 function boundLine(coordinates) {\n coordinates.forEach(boundPoint);\n }\n\n function boundMultiLine(coordinates) {\n coordinates.forEach(boundLine);\n }\n\n for (var key in objects) {\n boundGeometry(objects[key]);\n }\n\n return x1 >= x0 && y1 >= y0 ? [x0, y0, x1, y1] : undefined;\n}\n","export default function(size, hash, equal, type, empty) {\n if (arguments.length === 3) {\n type = Array;\n empty = null;\n }\n\n var store = new type(size = 1 << Math.max(4, Math.ceil(Math.log(size) / Math.LN2))),\n mask = size - 1;\n\n for (var i = 0; i < size; ++i) {\n store[i] = empty;\n }\n\n function add(value) {\n var index = hash(value) & mask,\n match = store[index],\n collisions = 0;\n while (match != empty) {\n if (equal(match, value)) return true;\n if (++collisions >= size) throw new Error(\"full hashset\");\n match = store[index = (index + 1) & mask];\n }\n store[index] = value;\n return true;\n }\n\n function has(value) {\n var index = hash(value) & mask,\n match = store[index],\n collisions = 0;\n while (match != empty) {\n if (equal(match, value)) return true;\n if (++collisions >= size) break;\n match = store[index = (index + 1) & mask];\n }\n return false;\n }\n\n function values() {\n var values = [];\n for (var i = 0, n = store.length; i < n; ++i) {\n var match = store[i];\n if (match != empty) values.push(match);\n }\n return values;\n }\n\n return {\n add: add,\n has: has,\n values: values\n };\n}\n","export default function(size, hash, equal, keyType, keyEmpty, valueType) {\n if (arguments.length === 3) {\n keyType = valueType = Array;\n keyEmpty = null;\n }\n\n var keystore = new keyType(size = 1 << Math.max(4, Math.ceil(Math.log(size) / Math.LN2))),\n valstore = new valueType(size),\n mask = size - 1;\n\n for (var i = 0; i < size; ++i) {\n keystore[i] = keyEmpty;\n }\n\n function set(key, value) {\n var index = hash(key) & mask,\n matchKey = keystore[index],\n collisions = 0;\n while (matchKey != keyEmpty) {\n if (equal(matchKey, key)) return valstore[index] = value;\n if (++collisions >= size) throw new Error(\"full hashmap\");\n matchKey = keystore[index = (index + 1) & mask];\n }\n keystore[index] = key;\n valstore[index] = value;\n return value;\n }\n\n function maybeSet(key, value) {\n var index = hash(key) & mask,\n matchKey = keystore[index],\n collisions = 0;\n while (matchKey != keyEmpty) {\n if (equal(matchKey, key)) return valstore[index];\n if (++collisions >= size) throw new Error(\"full hashmap\");\n matchKey = keystore[index = (index + 1) & mask];\n }\n keystore[index] = key;\n valstore[index] = value;\n return value;\n }\n\n function get(key, missingValue) {\n var index = hash(key) & mask,\n matchKey = keystore[index],\n collisions = 0;\n while (matchKey != keyEmpty) {\n if (equal(matchKey, key)) return valstore[index];\n if (++collisions >= size) break;\n matchKey = keystore[index = (index + 1) & mask];\n }\n return missingValue;\n }\n\n function keys() {\n var keys = [];\n for (var i = 0, n = keystore.length; i < n; ++i) {\n var matchKey = keystore[i];\n if (matchKey != keyEmpty) keys.push(matchKey);\n }\n return keys;\n }\n\n return {\n set: set,\n maybeSet: maybeSet, // set if unset\n get: get,\n keys: keys\n };\n}\n","export default function(pointA, pointB) {\n return pointA[0] === pointB[0] && pointA[1] === pointB[1];\n}\n","// TODO if quantized, use simpler Int32 hashing?\n\nvar buffer = new ArrayBuffer(16),\n floats = new Float64Array(buffer),\n uints = new Uint32Array(buffer);\n\nexport default function(point) {\n floats[0] = point[0];\n floats[1] = point[1];\n var hash = uints[0] ^ uints[1];\n hash = hash << 5 ^ hash >> 7 ^ uints[2] ^ uints[3];\n return hash & 0x7fffffff;\n}\n","import hashset from \"./hash/hashset\";\nimport hashmap from \"./hash/hashmap\";\nimport equalPoint from \"./hash/point-equal\";\nimport hashPoint from \"./hash/point-hash\";\n\n// Given an extracted (pre-)topology, identifies all of the junctions. These are\n// the points at which arcs (lines or rings) will need to be cut so that each\n// arc is represented uniquely.\n//\n// A junction is a point where at least one arc deviates from another arc going\n// through the same point. For example, consider the point B. If there is a arc\n// through ABC and another arc through CBA, then B is not a junction because in\n// both cases the adjacent point pairs are {A,C}. However, if there is an\n// additional arc ABD, then {A,D} != {A,C}, and thus B becomes a junction.\n//\n// For a closed ring ABCA, the first point A’s adjacent points are the second\n// and last point {B,C}. For a line, the first and last point are always\n// considered junctions, even if the line is closed; this ensures that a closed\n// line is never rotated.\nexport default function(topology) {\n var coordinates = topology.coordinates,\n lines = topology.lines,\n rings = topology.rings,\n indexes = index(),\n visitedByIndex = new Int32Array(coordinates.length),\n leftByIndex = new Int32Array(coordinates.length),\n rightByIndex = new Int32Array(coordinates.length),\n junctionByIndex = new Int8Array(coordinates.length),\n junctionCount = 0, // upper bound on number of junctions\n i, n,\n previousIndex,\n currentIndex,\n nextIndex;\n\n for (i = 0, n = coordinates.length; i < n; ++i) {\n visitedByIndex[i] = leftByIndex[i] = rightByIndex[i] = -1;\n }\n\n for (i = 0, n = lines.length; i < n; ++i) {\n var line = lines[i],\n lineStart = line[0],\n lineEnd = line[1];\n currentIndex = indexes[lineStart];\n nextIndex = indexes[++lineStart];\n ++junctionCount, junctionByIndex[currentIndex] = 1; // start\n while (++lineStart <= lineEnd) {\n sequence(i, previousIndex = currentIndex, currentIndex = nextIndex, nextIndex = indexes[lineStart]);\n }\n ++junctionCount, junctionByIndex[nextIndex] = 1; // end\n }\n\n for (i = 0, n = coordinates.length; i < n; ++i) {\n visitedByIndex[i] = -1;\n }\n\n for (i = 0, n = rings.length; i < n; ++i) {\n var ring = rings[i],\n ringStart = ring[0] + 1,\n ringEnd = ring[1];\n previousIndex = indexes[ringEnd - 1];\n currentIndex = indexes[ringStart - 1];\n nextIndex = indexes[ringStart];\n sequence(i, previousIndex, currentIndex, nextIndex);\n while (++ringStart <= ringEnd) {\n sequence(i, previousIndex = currentIndex, currentIndex = nextIndex, nextIndex = indexes[ringStart]);\n }\n }\n\n function sequence(i, previousIndex, currentIndex, nextIndex) {\n if (visitedByIndex[currentIndex] === i) return; // ignore self-intersection\n visitedByIndex[currentIndex] = i;\n var leftIndex = leftByIndex[currentIndex];\n if (leftIndex >= 0) {\n var rightIndex = rightByIndex[currentIndex];\n if ((leftIndex !== previousIndex || rightIndex !== nextIndex)\n && (leftIndex !== nextIndex || rightIndex !== previousIndex)) {\n ++junctionCount, junctionByIndex[currentIndex] = 1;\n }\n } else {\n leftByIndex[currentIndex] = previousIndex;\n rightByIndex[currentIndex] = nextIndex;\n }\n }\n\n function index() {\n var indexByPoint = hashmap(coordinates.length * 1.4, hashIndex, equalIndex, Int32Array, -1, Int32Array),\n indexes = new Int32Array(coordinates.length);\n\n for (var i = 0, n = coordinates.length; i < n; ++i) {\n indexes[i] = indexByPoint.maybeSet(i, i);\n }\n\n return indexes;\n }\n\n function hashIndex(i) {\n return hashPoint(coordinates[i]);\n }\n\n function equalIndex(i, j) {\n return equalPoint(coordinates[i], coordinates[j]);\n }\n\n visitedByIndex = leftByIndex = rightByIndex = null;\n\n var junctionByPoint = hashset(junctionCount * 1.4, hashPoint, equalPoint), j;\n\n // Convert back to a standard hashset by point for caller convenience.\n for (i = 0, n = coordinates.length; i < n; ++i) {\n if (junctionByIndex[j = indexes[i]]) {\n junctionByPoint.add(coordinates[j]);\n }\n }\n\n return junctionByPoint;\n}\n","import join from \"./join\";\n\n// Given an extracted (pre-)topology, cuts (or rotates) arcs so that all shared\n// point sequences are identified. The topology can then be subsequently deduped\n// to remove exact duplicate arcs.\nexport default function(topology) {\n var junctions = join(topology),\n coordinates = topology.coordinates,\n lines = topology.lines,\n rings = topology.rings,\n next,\n i, n;\n\n for (i = 0, n = lines.length; i < n; ++i) {\n var line = lines[i],\n lineMid = line[0],\n lineEnd = line[1];\n while (++lineMid < lineEnd) {\n if (junctions.has(coordinates[lineMid])) {\n next = {0: lineMid, 1: line[1]};\n line[1] = lineMid;\n line = line.next = next;\n }\n }\n }\n\n for (i = 0, n = rings.length; i < n; ++i) {\n var ring = rings[i],\n ringStart = ring[0],\n ringMid = ringStart,\n ringEnd = ring[1],\n ringFixed = junctions.has(coordinates[ringStart]);\n while (++ringMid < ringEnd) {\n if (junctions.has(coordinates[ringMid])) {\n if (ringFixed) {\n next = {0: ringMid, 1: ring[1]};\n ring[1] = ringMid;\n ring = ring.next = next;\n } else { // For the first junction, we can rotate rather than cut.\n rotateArray(coordinates, ringStart, ringEnd, ringEnd - ringMid);\n coordinates[ringEnd] = coordinates[ringStart];\n ringFixed = true;\n ringMid = ringStart; // restart; we may have skipped junctions\n }\n }\n }\n }\n\n return topology;\n}\n\nfunction rotateArray(array, start, end, offset) {\n reverse(array, start, end);\n reverse(array, start, start + offset);\n reverse(array, start + offset, end);\n}\n\nfunction reverse(array, start, end) {\n for (var mid = start + ((end-- - start) >> 1), t; start < mid; ++start, --end) {\n t = array[start], array[start] = array[end], array[end] = t;\n }\n}\n","import hashmap from \"./hash/hashmap\";\nimport equalPoint from \"./hash/point-equal\";\nimport hashPoint from \"./hash/point-hash\";\n\n// Given a cut topology, combines duplicate arcs.\nexport default function(topology) {\n var coordinates = topology.coordinates,\n lines = topology.lines, line,\n rings = topology.rings, ring,\n arcCount = lines.length + rings.length,\n i, n;\n\n delete topology.lines;\n delete topology.rings;\n\n // Count the number of (non-unique) arcs to initialize the hashmap safely.\n for (i = 0, n = lines.length; i < n; ++i) {\n line = lines[i]; while (line = line.next) ++arcCount;\n }\n for (i = 0, n = rings.length; i < n; ++i) {\n ring = rings[i]; while (ring = ring.next) ++arcCount;\n }\n\n var arcsByEnd = hashmap(arcCount * 2 * 1.4, hashPoint, equalPoint),\n arcs = topology.arcs = [];\n\n for (i = 0, n = lines.length; i < n; ++i) {\n line = lines[i];\n do {\n dedupLine(line);\n } while (line = line.next);\n }\n\n for (i = 0, n = rings.length; i < n; ++i) {\n ring = rings[i];\n if (ring.next) { // arc is no longer closed\n do {\n dedupLine(ring);\n } while (ring = ring.next);\n } else {\n dedupRing(ring);\n }\n }\n\n function dedupLine(arc) {\n var startPoint,\n endPoint,\n startArcs, startArc,\n endArcs, endArc,\n i, n;\n\n // Does this arc match an existing arc in order?\n if (startArcs = arcsByEnd.get(startPoint = coordinates[arc[0]])) {\n for (i = 0, n = startArcs.length; i < n; ++i) {\n startArc = startArcs[i];\n if (equalLine(startArc, arc)) {\n arc[0] = startArc[0];\n arc[1] = startArc[1];\n return;\n }\n }\n }\n\n // Does this arc match an existing arc in reverse order?\n if (endArcs = arcsByEnd.get(endPoint = coordinates[arc[1]])) {\n for (i = 0, n = endArcs.length; i < n; ++i) {\n endArc = endArcs[i];\n if (reverseEqualLine(endArc, arc)) {\n arc[1] = endArc[0];\n arc[0] = endArc[1];\n return;\n }\n }\n }\n\n if (startArcs) startArcs.push(arc); else arcsByEnd.set(startPoint, [arc]);\n if (endArcs) endArcs.push(arc); else arcsByEnd.set(endPoint, [arc]);\n arcs.push(arc);\n }\n\n function dedupRing(arc) {\n var endPoint,\n endArcs,\n endArc,\n i, n;\n\n // Does this arc match an existing line in order, or reverse order?\n // Rings are closed, so their start point and end point is the same.\n if (endArcs = arcsByEnd.get(endPoint = coordinates[arc[0]])) {\n for (i = 0, n = endArcs.length; i < n; ++i) {\n endArc = endArcs[i];\n if (equalRing(endArc, arc)) {\n arc[0] = endArc[0];\n arc[1] = endArc[1];\n return;\n }\n if (reverseEqualRing(endArc, arc)) {\n arc[0] = endArc[1];\n arc[1] = endArc[0];\n return;\n }\n }\n }\n\n // Otherwise, does this arc match an existing ring in order, or reverse order?\n if (endArcs = arcsByEnd.get(endPoint = coordinates[arc[0] + findMinimumOffset(arc)])) {\n for (i = 0, n = endArcs.length; i < n; ++i) {\n endArc = endArcs[i];\n if (equalRing(endArc, arc)) {\n arc[0] = endArc[0];\n arc[1] = endArc[1];\n return;\n }\n if (reverseEqualRing(endArc, arc)) {\n arc[0] = endArc[1];\n arc[1] = endArc[0];\n return;\n }\n }\n }\n\n if (endArcs) endArcs.push(arc); else arcsByEnd.set(endPoint, [arc]);\n arcs.push(arc);\n }\n\n function equalLine(arcA, arcB) {\n var ia = arcA[0], ib = arcB[0],\n ja = arcA[1], jb = arcB[1];\n if (ia - ja !== ib - jb) return false;\n for (; ia <= ja; ++ia, ++ib) if (!equalPoint(coordinates[ia], coordinates[ib])) return false;\n return true;\n }\n\n function reverseEqualLine(arcA, arcB) {\n var ia = arcA[0], ib = arcB[0],\n ja = arcA[1], jb = arcB[1];\n if (ia - ja !== ib - jb) return false;\n for (; ia <= ja; ++ia, --jb) if (!equalPoint(coordinates[ia], coordinates[jb])) return false;\n return true;\n }\n\n function equalRing(arcA, arcB) {\n var ia = arcA[0], ib = arcB[0],\n ja = arcA[1], jb = arcB[1],\n n = ja - ia;\n if (n !== jb - ib) return false;\n var ka = findMinimumOffset(arcA),\n kb = findMinimumOffset(arcB);\n for (var i = 0; i < n; ++i) {\n if (!equalPoint(coordinates[ia + (i + ka) % n], coordinates[ib + (i + kb) % n])) return false;\n }\n return true;\n }\n\n function reverseEqualRing(arcA, arcB) {\n var ia = arcA[0], ib = arcB[0],\n ja = arcA[1], jb = arcB[1],\n n = ja - ia;\n if (n !== jb - ib) return false;\n var ka = findMinimumOffset(arcA),\n kb = n - findMinimumOffset(arcB);\n for (var i = 0; i < n; ++i) {\n if (!equalPoint(coordinates[ia + (i + ka) % n], coordinates[jb - (i + kb) % n])) return false;\n }\n return true;\n }\n\n // Rings are rotated to a consistent, but arbitrary, start point.\n // This is necessary to detect when a ring and a rotated copy are dupes.\n function findMinimumOffset(arc) {\n var start = arc[0],\n end = arc[1],\n mid = start,\n minimum = mid,\n minimumPoint = coordinates[mid];\n while (++mid < end) {\n var point = coordinates[mid];\n if (point[0] < minimumPoint[0] || point[0] === minimumPoint[0] && point[1] < minimumPoint[1]) {\n minimum = mid;\n minimumPoint = point;\n }\n }\n return minimum - start;\n }\n\n return topology;\n}\n","// Given an array of arcs in absolute (but already quantized!) coordinates,\n// converts to fixed-point delta encoding.\n// This is a destructive operation that modifies the given arcs!\nexport default function(arcs) {\n var i = -1,\n n = arcs.length;\n\n while (++i < n) {\n var arc = arcs[i],\n j = 0,\n k = 1,\n m = arc.length,\n point = arc[0],\n x0 = point[0],\n y0 = point[1],\n x1,\n y1;\n\n while (++j < m) {\n point = arc[j], x1 = point[0], y1 = point[1];\n if (x1 !== x0 || y1 !== y0) arc[k++] = [x1 - x0, y1 - y0], x0 = x1, y0 = y1;\n }\n\n if (k === 1) arc[k++] = [0, 0]; // Each arc must be an array of two or more positions.\n\n arc.length = k;\n }\n\n return arcs;\n}\n","// Extracts the lines and rings from the specified hash of geometry objects.\n//\n// Returns an object with three properties:\n//\n// * coordinates - shared buffer of [x, y] coordinates\n// * lines - lines extracted from the hash, of the form [start, end]\n// * rings - rings extracted from the hash, of the form [start, end]\n//\n// For each ring or line, start and end represent inclusive indexes into the\n// coordinates buffer. For rings (and closed lines), coordinates[start] equals\n// coordinates[end].\n//\n// For each line or polygon geometry in the input hash, including nested\n// geometries as in geometry collections, the `coordinates` array is replaced\n// with an equivalent `arcs` array that, for each line (for line string\n// geometries) or ring (for polygon geometries), points to one of the above\n// lines or rings.\nexport default function(objects) {\n var index = -1,\n lines = [],\n rings = [],\n coordinates = [];\n\n function extractGeometry(geometry) {\n if (geometry && extractGeometryType.hasOwnProperty(geometry.type)) extractGeometryType[geometry.type](geometry);\n }\n\n var extractGeometryType = {\n GeometryCollection: function(o) { o.geometries.forEach(extractGeometry); },\n LineString: function(o) { o.arcs = extractLine(o.arcs); },\n MultiLineString: function(o) { o.arcs = o.arcs.map(extractLine); },\n Polygon: function(o) { o.arcs = o.arcs.map(extractRing); },\n MultiPolygon: function(o) { o.arcs = o.arcs.map(extractMultiRing); }\n };\n\n function extractLine(line) {\n for (var i = 0, n = line.length; i < n; ++i) coordinates[++index] = line[i];\n var arc = {0: index - n + 1, 1: index};\n lines.push(arc);\n return arc;\n }\n\n function extractRing(ring) {\n for (var i = 0, n = ring.length; i < n; ++i) coordinates[++index] = ring[i];\n var arc = {0: index - n + 1, 1: index};\n rings.push(arc);\n return arc;\n }\n\n function extractMultiRing(rings) {\n return rings.map(extractRing);\n }\n\n for (var key in objects) {\n extractGeometry(objects[key]);\n }\n\n return {\n type: \"Topology\",\n coordinates: coordinates,\n lines: lines,\n rings: rings,\n objects: objects\n };\n}\n","// Given a hash of GeoJSON objects, returns a hash of GeoJSON geometry objects.\n// Any null input geometry objects are represented as {type: null} in the output.\n// Any feature.{id,properties,bbox} are transferred to the output geometry object.\n// Each output geometry object is a shallow copy of the input (e.g., properties, coordinates)!\nexport default function(inputs) {\n var outputs = {}, key;\n for (key in inputs) outputs[key] = geomifyObject(inputs[key]);\n return outputs;\n}\n\nfunction geomifyObject(input) {\n return input == null ? {type: null}\n : (input.type === \"FeatureCollection\" ? geomifyFeatureCollection\n : input.type === \"Feature\" ? geomifyFeature\n : geomifyGeometry)(input);\n}\n\nfunction geomifyFeatureCollection(input) {\n var output = {type: \"GeometryCollection\", geometries: input.features.map(geomifyFeature)};\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n}\n\nfunction geomifyFeature(input) {\n var output = geomifyGeometry(input.geometry), key; // eslint-disable-line no-unused-vars\n if (input.id != null) output.id = input.id;\n if (input.bbox != null) output.bbox = input.bbox;\n for (key in input.properties) { output.properties = input.properties; break; }\n return output;\n}\n\nfunction geomifyGeometry(input) {\n if (input == null) return {type: null};\n var output = input.type === \"GeometryCollection\" ? {type: \"GeometryCollection\", geometries: input.geometries.map(geomifyGeometry)}\n : input.type === \"Point\" || input.type === \"MultiPoint\" ? {type: input.type, coordinates: input.coordinates}\n : {type: input.type, arcs: input.coordinates}; // TODO Check for unknown types?\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n}\n","export default function(objects, bbox, n) {\n var x0 = bbox[0],\n y0 = bbox[1],\n x1 = bbox[2],\n y1 = bbox[3],\n kx = x1 - x0 ? (n - 1) / (x1 - x0) : 1,\n ky = y1 - y0 ? (n - 1) / (y1 - y0) : 1;\n\n function quantizePoint(input) {\n return [Math.round((input[0] - x0) * kx), Math.round((input[1] - y0) * ky)];\n }\n\n function quantizePoints(input, m) {\n var i = -1,\n j = 0,\n n = input.length,\n output = new Array(n), // pessimistic\n pi,\n px,\n py,\n x,\n y;\n\n while (++i < n) {\n pi = input[i];\n x = Math.round((pi[0] - x0) * kx);\n y = Math.round((pi[1] - y0) * ky);\n if (x !== px || y !== py) output[j++] = [px = x, py = y]; // non-coincident points\n }\n\n output.length = j;\n while (j < m) j = output.push([output[0][0], output[0][1]]);\n return output;\n }\n\n function quantizeLine(input) {\n return quantizePoints(input, 2);\n }\n\n function quantizeRing(input) {\n return quantizePoints(input, 4);\n }\n\n function quantizePolygon(input) {\n return input.map(quantizeRing);\n }\n\n function quantizeGeometry(o) {\n if (o != null && quantizeGeometryType.hasOwnProperty(o.type)) quantizeGeometryType[o.type](o);\n }\n\n var quantizeGeometryType = {\n GeometryCollection: function(o) { o.geometries.forEach(quantizeGeometry); },\n Point: function(o) { o.coordinates = quantizePoint(o.coordinates); },\n MultiPoint: function(o) { o.coordinates = o.coordinates.map(quantizePoint); },\n LineString: function(o) { o.arcs = quantizeLine(o.arcs); },\n MultiLineString: function(o) { o.arcs = o.arcs.map(quantizeLine); },\n Polygon: function(o) { o.arcs = quantizePolygon(o.arcs); },\n MultiPolygon: function(o) { o.arcs = o.arcs.map(quantizePolygon); }\n };\n\n for (var key in objects) {\n quantizeGeometry(objects[key]);\n }\n\n return {\n scale: [1 / kx, 1 / ky],\n translate: [x0, y0]\n };\n}\n","import bounds from \"./bounds\";\nimport cut from \"./cut\";\nimport dedup from \"./dedup\";\nimport delta from \"./delta\";\nimport extract from \"./extract\";\nimport geometry from \"./geometry\";\nimport hashmap from \"./hash/hashmap\";\nimport prequantize from \"./prequantize\";\n\n// Constructs the TopoJSON Topology for the specified hash of features.\n// Each object in the specified hash must be a GeoJSON object,\n// meaning FeatureCollection, a Feature or a geometry object.\nexport default function(objects, quantization) {\n var bbox = bounds(objects = geometry(objects)),\n transform = quantization > 0 && bbox && prequantize(objects, bbox, quantization),\n topology = dedup(cut(extract(objects))),\n coordinates = topology.coordinates,\n indexByArc = hashmap(topology.arcs.length * 1.4, hashArc, equalArc);\n\n objects = topology.objects; // for garbage collection\n topology.bbox = bbox;\n topology.arcs = topology.arcs.map(function(arc, i) {\n indexByArc.set(arc, i);\n return coordinates.slice(arc[0], arc[1] + 1);\n });\n\n delete topology.coordinates;\n coordinates = null;\n\n function indexGeometry(geometry) {\n if (geometry && indexGeometryType.hasOwnProperty(geometry.type)) indexGeometryType[geometry.type](geometry);\n }\n\n var indexGeometryType = {\n GeometryCollection: function(o) { o.geometries.forEach(indexGeometry); },\n LineString: function(o) { o.arcs = indexArcs(o.arcs); },\n MultiLineString: function(o) { o.arcs = o.arcs.map(indexArcs); },\n Polygon: function(o) { o.arcs = o.arcs.map(indexArcs); },\n MultiPolygon: function(o) { o.arcs = o.arcs.map(indexMultiArcs); }\n };\n\n function indexArcs(arc) {\n var indexes = [];\n do {\n var index = indexByArc.get(arc);\n indexes.push(arc[0] < arc[1] ? index : ~index);\n } while (arc = arc.next);\n return indexes;\n }\n\n function indexMultiArcs(arcs) {\n return arcs.map(indexArcs);\n }\n\n for (var key in objects) {\n indexGeometry(objects[key]);\n }\n\n if (transform) {\n topology.transform = transform;\n topology.arcs = delta(topology.arcs);\n }\n\n return topology;\n}\n\nfunction hashArc(arc) {\n var i = arc[0], j = arc[1], t;\n if (j < i) t = i, i = j, j = t;\n return i + 31 * j;\n}\n\nfunction equalArc(arcA, arcB) {\n var ia = arcA[0], ja = arcA[1],\n ib = arcB[0], jb = arcB[1], t;\n if (ja < ia) t = ia, ia = ja, ja = t;\n if (jb < ib) t = ib, ib = jb, jb = t;\n return ia === ib && ja === jb;\n}\n","export {default as topology} from \"./src/topology\";\n","var meta = require('@turf/meta');\nvar invariant = require('@turf/invariant');\nvar lineOverlap = require('@turf/line-overlap');\nvar lineIntersect = require('@turf/line-intersect');\nvar GeojsonEquality = require('geojson-equality');\nvar coordAll = meta.coordAll;\nvar segmentEach = meta.segmentEach;\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Compares two geometries of the same dimension and returns true if their intersection set results in a geometry\n * different from both but of the same dimension. It applies to Polygon/Polygon, LineString/LineString,\n * Multipoint/Multipoint, MultiLineString/MultiLineString and MultiPolygon/MultiPolygon.\n *\n * @name booleanOverlap\n * @param {Geometry|Feature} feature1 input\n * @param {Geometry|Feature} feature2 input\n * @returns {boolean} true/false\n * @example\n * var poly1 = turf.polygon([[[0,0],[0,5],[5,5],[5,0],[0,0]]]);\n * var poly2 = turf.polygon([[[1,1],[1,6],[6,6],[6,1],[1,1]]]);\n * var poly3 = turf.polygon([[[10,10],[10,15],[15,15],[15,10],[10,10]]]);\n *\n * turf.booleanOverlap(poly1, poly2)\n * //=true\n * turf.booleanOverlap(poly2, poly3)\n * //=false\n */\nmodule.exports = function (feature1, feature2) {\n // validation\n if (!feature1) throw new Error('feature1 is required');\n if (!feature2) throw new Error('feature2 is required');\n var type1 = getGeomType(feature1);\n var type2 = getGeomType(feature2);\n if (type1 !== type2) throw new Error('features must be of the same type');\n if (type1 === 'Point') throw new Error('Point geometry not supported');\n\n // features must be not equal\n var equality = new GeojsonEquality({precision: 6});\n if (equality.compare(feature1, feature2)) return false;\n\n var overlap = 0;\n\n switch (type1) {\n case 'MultiPoint':\n var coords1 = coordAll(feature1);\n var coords2 = coordAll(feature2);\n coords1.forEach(function (coord1) {\n coords2.forEach(function (coord2) {\n if (coord1[0] === coord2[0] && coord1[1] === coord2[1]) overlap++;\n });\n });\n break;\n\n case 'LineString':\n case 'MultiLineString':\n segmentEach(feature1, function (segment1) {\n segmentEach(feature2, function (segment2) {\n if (lineOverlap(segment1, segment2).features.length) overlap++;\n });\n });\n break;\n\n case 'Polygon':\n case 'MultiPolygon':\n segmentEach(feature1, function (segment1) {\n segmentEach(feature2, function (segment2) {\n if (lineIntersect(segment1, segment2).features.length) overlap++;\n });\n });\n break;\n }\n\n return overlap > 0;\n};\n","var area = require('@mapbox/geojson-area').geometry;\nvar geomReduce = require('@turf/meta').geomReduce;\n\n/**\n * Takes one or more features and returns their area in square meters.\n *\n * @name area\n * @param {FeatureCollection|Feature} geojson input GeoJSON feature(s)\n * @returns {number} area in square meters\n * @example\n * var polygon = turf.polygon([[[125, -15], [113, -22], [154, -27], [144, -15], [125, -15]]]);\n *\n * var area = turf.area(polygon);\n *\n * //addToMap\n * var addToMap = [polygon]\n * polygon.properties.area = area\n */\nmodule.exports = function (geojson) {\n return geomReduce(geojson, function (value, geometry) {\n return value + area(geometry);\n }, 0);\n};\n","var inside = require('@turf/inside');\nvar featureCollection = require('@turf/helpers').featureCollection;\n\n/**\n * Takes a set of {@link Point|points} and a set of {@link Polygon|polygons} and returns the points that fall within the polygons.\n *\n * @name within\n * @param {FeatureCollection} points input points\n * @param {FeatureCollection} polygons input polygons\n * @returns {FeatureCollection} points that land within at least one polygon\n * @example\n * var searchWithin = turf.featureCollection([\n * turf.polygon([[\n * [-46.653,-23.543],\n * [-46.634,-23.5346],\n * [-46.613,-23.543],\n * [-46.614,-23.559],\n * [-46.631,-23.567],\n * [-46.653,-23.560],\n * [-46.653,-23.543]\n * ]])\n * ]);\n * var points = turf.featureCollection([\n * turf.point([-46.6318, -23.5523]),\n * turf.point([-46.6246, -23.5325]),\n * turf.point([-46.6062, -23.5513]),\n * turf.point([-46.663, -23.554]),\n * turf.point([-46.643, -23.557])\n * ]);\n *\n * var ptsWithin = turf.within(points, searchWithin);\n *\n * //addToMap\n * var addToMap = [points, searchWithin, ptsWithin]\n * turf.featureEach(ptsWithin, function (currentFeature) {\n * currentFeature.properties['marker-size'] = 'large';\n * currentFeature.properties['marker-color'] = '#000';\n * });\n */\nmodule.exports = function (points, polygons) {\n var pointsWithin = featureCollection([]);\n for (var i = 0; i < polygons.features.length; i++) {\n for (var j = 0; j < points.features.length; j++) {\n var isInside = inside(points.features[j], polygons.features[i]);\n if (isInside) {\n pointsWithin.features.push(points.features[j]);\n }\n }\n }\n return pointsWithin;\n};\n","var lineSliceAlong = require('@turf/line-slice-along');\nvar lineDistance = require('@turf/line-distance');\nvar featureCollection = require('@turf/helpers').featureCollection;\nvar flattenEach = require('@turf/meta').flattenEach;\n\n/**\n * Divides a {@link LineString} into chunks of a specified length.\n * If the line is shorter than the segment length then the original line is returned.\n *\n * @name lineChunk\n * @param {FeatureCollection|Geometry|Feature} geojson the lines to split\n * @param {number} segmentLength how long to make each segment\n * @param {string}[units='kilometers'] units can be degrees, radians, miles, or kilometers\n * @param {boolean}[reverse=false] reverses coordinates to start the first chunked segment at the end\n * @returns {FeatureCollection} collection of line segments\n * @example\n * var line = turf.lineString([[-95, 40], [-93, 45], [-85, 50]]);\n *\n * var chunk = turf.lineChunk(line, 15, 'miles');\n *\n * //addToMap\n * var addToMap = [chunk];\n */\nmodule.exports = function (geojson, segmentLength, units, reverse) {\n if (!geojson) throw new Error('geojson is required');\n if (segmentLength <= 0) throw new Error('segmentLength must be greater than 0');\n var results = [];\n\n // Flatten each feature to simple LineString\n flattenEach(geojson, function (feature) {\n // reverses coordinates to start the first chunked segment at the end\n if (reverse) feature.geometry.coordinates = feature.geometry.coordinates.reverse();\n\n sliceLineSegments(feature, segmentLength, units, function (segment) {\n results.push(segment);\n });\n });\n return featureCollection(results);\n};\n\n/**\n * Slice Line Segments\n *\n * @private\n * @param {Feature} line GeoJSON LineString\n * @param {number} segmentLength how long to make each segment\n * @param {string}[units='kilometers'] units can be degrees, radians, miles, or kilometers\n * @param {Function} callback iterate over sliced line segments\n * @returns {void}\n */\nfunction sliceLineSegments(line, segmentLength, units, callback) {\n var lineLength = lineDistance(line, units);\n\n // If the line is shorter than the segment length then the orginal line is returned.\n if (lineLength <= segmentLength) return callback(line);\n\n var numberOfSegments = Math.floor(lineLength / segmentLength) + 1;\n for (var i = 0; i < numberOfSegments; i++) {\n var outline = lineSliceAlong(line, segmentLength * i, segmentLength * (i + 1), units);\n callback(outline, i);\n }\n}\n","(function () {\n var gju = this.gju = {};\n\n // Export the geojson object for **CommonJS**\n if (typeof module !== 'undefined' && module.exports) {\n module.exports = gju;\n }\n\n // adapted from http://www.kevlindev.com/gui/math/intersection/Intersection.js\n gju.lineStringsIntersect = function (l1, l2) {\n var intersects = [];\n for (var i = 0; i <= l1.coordinates.length - 2; ++i) {\n for (var j = 0; j <= l2.coordinates.length - 2; ++j) {\n var a1 = {\n x: l1.coordinates[i][1],\n y: l1.coordinates[i][0]\n },\n a2 = {\n x: l1.coordinates[i + 1][1],\n y: l1.coordinates[i + 1][0]\n },\n b1 = {\n x: l2.coordinates[j][1],\n y: l2.coordinates[j][0]\n },\n b2 = {\n x: l2.coordinates[j + 1][1],\n y: l2.coordinates[j + 1][0]\n },\n ua_t = (b2.x - b1.x) * (a1.y - b1.y) - (b2.y - b1.y) * (a1.x - b1.x),\n ub_t = (a2.x - a1.x) * (a1.y - b1.y) - (a2.y - a1.y) * (a1.x - b1.x),\n u_b = (b2.y - b1.y) * (a2.x - a1.x) - (b2.x - b1.x) * (a2.y - a1.y);\n if (u_b != 0) {\n var ua = ua_t / u_b,\n ub = ub_t / u_b;\n if (0 <= ua && ua <= 1 && 0 <= ub && ub <= 1) {\n intersects.push({\n 'type': 'Point',\n 'coordinates': [a1.x + ua * (a2.x - a1.x), a1.y + ua * (a2.y - a1.y)]\n });\n }\n }\n }\n }\n if (intersects.length == 0) intersects = false;\n return intersects;\n }\n\n // Bounding Box\n\n function boundingBoxAroundPolyCoords (coords) {\n var xAll = [], yAll = []\n\n for (var i = 0; i < coords[0].length; i++) {\n xAll.push(coords[0][i][1])\n yAll.push(coords[0][i][0])\n }\n\n xAll = xAll.sort(function (a,b) { return a - b })\n yAll = yAll.sort(function (a,b) { return a - b })\n\n return [ [xAll[0], yAll[0]], [xAll[xAll.length - 1], yAll[yAll.length - 1]] ]\n }\n\n gju.pointInBoundingBox = function (point, bounds) {\n return !(point.coordinates[1] < bounds[0][0] || point.coordinates[1] > bounds[1][0] || point.coordinates[0] < bounds[0][1] || point.coordinates[0] > bounds[1][1]) \n }\n\n // Point in Polygon\n // http://www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html#Listing the Vertices\n\n function pnpoly (x,y,coords) {\n var vert = [ [0,0] ]\n\n for (var i = 0; i < coords.length; i++) {\n for (var j = 0; j < coords[i].length; j++) {\n vert.push(coords[i][j])\n }\n\t vert.push(coords[i][0])\n vert.push([0,0])\n }\n\n var inside = false\n for (var i = 0, j = vert.length - 1; i < vert.length; j = i++) {\n if (((vert[i][0] > y) != (vert[j][0] > y)) && (x < (vert[j][1] - vert[i][1]) * (y - vert[i][0]) / (vert[j][0] - vert[i][0]) + vert[i][1])) inside = !inside\n }\n\n return inside\n }\n\n gju.pointInPolygon = function (p, poly) {\n var coords = (poly.type == \"Polygon\") ? [ poly.coordinates ] : poly.coordinates\n\n var insideBox = false\n for (var i = 0; i < coords.length; i++) {\n if (gju.pointInBoundingBox(p, boundingBoxAroundPolyCoords(coords[i]))) insideBox = true\n }\n if (!insideBox) return false\n\n var insidePoly = false\n for (var i = 0; i < coords.length; i++) {\n if (pnpoly(p.coordinates[1], p.coordinates[0], coords[i])) insidePoly = true\n }\n\n return insidePoly\n }\n\n // support multi (but not donut) polygons\n gju.pointInMultiPolygon = function (p, poly) {\n var coords_array = (poly.type == \"MultiPolygon\") ? [ poly.coordinates ] : poly.coordinates\n\n var insideBox = false\n var insidePoly = false\n for (var i = 0; i < coords_array.length; i++){\n var coords = coords_array[i];\n for (var j = 0; j < coords.length; j++) {\n if (!insideBox){\n if (gju.pointInBoundingBox(p, boundingBoxAroundPolyCoords(coords[j]))) {\n insideBox = true\n }\n }\n }\n if (!insideBox) return false\n for (var j = 0; j < coords.length; j++) {\n if (!insidePoly){\n if (pnpoly(p.coordinates[1], p.coordinates[0], coords[j])) {\n insidePoly = true\n }\n }\n }\n }\n\n return insidePoly\n }\n\n gju.numberToRadius = function (number) {\n return number * Math.PI / 180;\n }\n\n gju.numberToDegree = function (number) {\n return number * 180 / Math.PI;\n }\n\n // written with help from @tautologe\n gju.drawCircle = function (radiusInMeters, centerPoint, steps) {\n var center = [centerPoint.coordinates[1], centerPoint.coordinates[0]],\n dist = (radiusInMeters / 1000) / 6371,\n // convert meters to radiant\n radCenter = [gju.numberToRadius(center[0]), gju.numberToRadius(center[1])],\n steps = steps || 15,\n // 15 sided circle\n poly = [[center[0], center[1]]];\n for (var i = 0; i < steps; i++) {\n var brng = 2 * Math.PI * i / steps;\n var lat = Math.asin(Math.sin(radCenter[0]) * Math.cos(dist)\n + Math.cos(radCenter[0]) * Math.sin(dist) * Math.cos(brng));\n var lng = radCenter[1] + Math.atan2(Math.sin(brng) * Math.sin(dist) * Math.cos(radCenter[0]),\n Math.cos(dist) - Math.sin(radCenter[0]) * Math.sin(lat));\n poly[i] = [];\n poly[i][1] = gju.numberToDegree(lat);\n poly[i][0] = gju.numberToDegree(lng);\n }\n return {\n \"type\": \"Polygon\",\n \"coordinates\": [poly]\n };\n }\n\n // assumes rectangle starts at lower left point\n gju.rectangleCentroid = function (rectangle) {\n var bbox = rectangle.coordinates[0];\n var xmin = bbox[0][0],\n ymin = bbox[0][1],\n xmax = bbox[2][0],\n ymax = bbox[2][1];\n var xwidth = xmax - xmin;\n var ywidth = ymax - ymin;\n return {\n 'type': 'Point',\n 'coordinates': [xmin + xwidth / 2, ymin + ywidth / 2]\n };\n }\n\n // from http://www.movable-type.co.uk/scripts/latlong.html\n gju.pointDistance = function (pt1, pt2) {\n var lon1 = pt1.coordinates[0],\n lat1 = pt1.coordinates[1],\n lon2 = pt2.coordinates[0],\n lat2 = pt2.coordinates[1],\n dLat = gju.numberToRadius(lat2 - lat1),\n dLon = gju.numberToRadius(lon2 - lon1),\n a = Math.pow(Math.sin(dLat / 2), 2) + Math.cos(gju.numberToRadius(lat1))\n * Math.cos(gju.numberToRadius(lat2)) * Math.pow(Math.sin(dLon / 2), 2),\n c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));\n return (6371 * c) * 1000; // returns meters\n },\n\n // checks if geometry lies entirely within a circle\n // works with Point, LineString, Polygon\n gju.geometryWithinRadius = function (geometry, center, radius) {\n if (geometry.type == 'Point') {\n return gju.pointDistance(geometry, center) <= radius;\n } else if (geometry.type == 'LineString' || geometry.type == 'Polygon') {\n var point = {};\n var coordinates;\n if (geometry.type == 'Polygon') {\n // it's enough to check the exterior ring of the Polygon\n coordinates = geometry.coordinates[0];\n } else {\n coordinates = geometry.coordinates;\n }\n for (var i in coordinates) {\n point.coordinates = coordinates[i];\n if (gju.pointDistance(point, center) > radius) {\n return false;\n }\n }\n }\n return true;\n }\n\n // adapted from http://paulbourke.net/geometry/polyarea/javascript.txt\n gju.area = function (polygon) {\n var area = 0;\n // TODO: polygon holes at coordinates[1]\n var points = polygon.coordinates[0];\n var j = points.length - 1;\n var p1, p2;\n\n for (var i = 0; i < points.length; j = i++) {\n var p1 = {\n x: points[i][1],\n y: points[i][0]\n };\n var p2 = {\n x: points[j][1],\n y: points[j][0]\n };\n area += p1.x * p2.y;\n area -= p1.y * p2.x;\n }\n\n area /= 2;\n return area;\n },\n\n // adapted from http://paulbourke.net/geometry/polyarea/javascript.txt\n gju.centroid = function (polygon) {\n var f, x = 0,\n y = 0;\n // TODO: polygon holes at coordinates[1]\n var points = polygon.coordinates[0];\n var j = points.length - 1;\n var p1, p2;\n\n for (var i = 0; i < points.length; j = i++) {\n var p1 = {\n x: points[i][1],\n y: points[i][0]\n };\n var p2 = {\n x: points[j][1],\n y: points[j][0]\n };\n f = p1.x * p2.y - p2.x * p1.y;\n x += (p1.x + p2.x) * f;\n y += (p1.y + p2.y) * f;\n }\n\n f = gju.area(polygon) * 6;\n return {\n 'type': 'Point',\n 'coordinates': [y / f, x / f]\n };\n },\n\n gju.simplify = function (source, kink) { /* source[] array of geojson points */\n /* kink\tin metres, kinks above this depth kept */\n /* kink depth is the height of the triangle abc where a-b and b-c are two consecutive line segments */\n kink = kink || 20;\n source = source.map(function (o) {\n return {\n lng: o.coordinates[0],\n lat: o.coordinates[1]\n }\n });\n\n var n_source, n_stack, n_dest, start, end, i, sig;\n var dev_sqr, max_dev_sqr, band_sqr;\n var x12, y12, d12, x13, y13, d13, x23, y23, d23;\n var F = (Math.PI / 180.0) * 0.5;\n var index = new Array(); /* aray of indexes of source points to include in the reduced line */\n var sig_start = new Array(); /* indices of start & end of working section */\n var sig_end = new Array();\n\n /* check for simple cases */\n\n if (source.length < 3) return (source); /* one or two points */\n\n /* more complex case. initialize stack */\n\n n_source = source.length;\n band_sqr = kink * 360.0 / (2.0 * Math.PI * 6378137.0); /* Now in degrees */\n band_sqr *= band_sqr;\n n_dest = 0;\n sig_start[0] = 0;\n sig_end[0] = n_source - 1;\n n_stack = 1;\n\n /* while the stack is not empty ... */\n while (n_stack > 0) {\n\n /* ... pop the top-most entries off the stacks */\n\n start = sig_start[n_stack - 1];\n end = sig_end[n_stack - 1];\n n_stack--;\n\n if ((end - start) > 1) { /* any intermediate points ? */\n\n /* ... yes, so find most deviant intermediate point to\n either side of line joining start & end points */\n\n x12 = (source[end].lng() - source[start].lng());\n y12 = (source[end].lat() - source[start].lat());\n if (Math.abs(x12) > 180.0) x12 = 360.0 - Math.abs(x12);\n x12 *= Math.cos(F * (source[end].lat() + source[start].lat())); /* use avg lat to reduce lng */\n d12 = (x12 * x12) + (y12 * y12);\n\n for (i = start + 1, sig = start, max_dev_sqr = -1.0; i < end; i++) {\n\n x13 = source[i].lng() - source[start].lng();\n y13 = source[i].lat() - source[start].lat();\n if (Math.abs(x13) > 180.0) x13 = 360.0 - Math.abs(x13);\n x13 *= Math.cos(F * (source[i].lat() + source[start].lat()));\n d13 = (x13 * x13) + (y13 * y13);\n\n x23 = source[i].lng() - source[end].lng();\n y23 = source[i].lat() - source[end].lat();\n if (Math.abs(x23) > 180.0) x23 = 360.0 - Math.abs(x23);\n x23 *= Math.cos(F * (source[i].lat() + source[end].lat()));\n d23 = (x23 * x23) + (y23 * y23);\n\n if (d13 >= (d12 + d23)) dev_sqr = d23;\n else if (d23 >= (d12 + d13)) dev_sqr = d13;\n else dev_sqr = (x13 * y12 - y13 * x12) * (x13 * y12 - y13 * x12) / d12; // solve triangle\n if (dev_sqr > max_dev_sqr) {\n sig = i;\n max_dev_sqr = dev_sqr;\n }\n }\n\n if (max_dev_sqr < band_sqr) { /* is there a sig. intermediate point ? */\n /* ... no, so transfer current start point */\n index[n_dest] = start;\n n_dest++;\n } else { /* ... yes, so push two sub-sections on stack for further processing */\n n_stack++;\n sig_start[n_stack - 1] = sig;\n sig_end[n_stack - 1] = end;\n n_stack++;\n sig_start[n_stack - 1] = start;\n sig_end[n_stack - 1] = sig;\n }\n } else { /* ... no intermediate points, so transfer current start point */\n index[n_dest] = start;\n n_dest++;\n }\n }\n\n /* transfer last point */\n index[n_dest] = n_source - 1;\n n_dest++;\n\n /* make return array */\n var r = new Array();\n for (var i = 0; i < n_dest; i++)\n r.push(source[index[i]]);\n\n return r.map(function (o) {\n return {\n type: \"Point\",\n coordinates: [o.lng, o.lat]\n }\n });\n }\n\n // http://www.movable-type.co.uk/scripts/latlong.html#destPoint\n gju.destinationPoint = function (pt, brng, dist) {\n dist = dist/6371; // convert dist to angular distance in radians\n brng = gju.numberToRadius(brng);\n\n var lon1 = gju.numberToRadius(pt.coordinates[0]);\n var lat1 = gju.numberToRadius(pt.coordinates[1]);\n\n var lat2 = Math.asin( Math.sin(lat1)*Math.cos(dist) +\n Math.cos(lat1)*Math.sin(dist)*Math.cos(brng) );\n var lon2 = lon1 + Math.atan2(Math.sin(brng)*Math.sin(dist)*Math.cos(lat1),\n Math.cos(dist)-Math.sin(lat1)*Math.sin(lat2));\n lon2 = (lon2+3*Math.PI) % (2*Math.PI) - Math.PI; // normalise to -180..+180º\n\n return {\n 'type': 'Point',\n 'coordinates': [gju.numberToDegree(lon2), gju.numberToDegree(lat2)]\n };\n };\n\n})();\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('LabelAndMessage',{attrs:{\"id\":_vm.id,\"label\":_vm.label,\"description\":_vm.combinedDescription}},[_c('span',{staticClass:\"bs-checkbox\",class:{inline: _vm.inline, 'has-error': _vm.dirty && _vm.required && !_vm.checked, 'has-success': _vm.dirty && _vm.required && _vm.checked}},[(!_vm.inline)?_c('div',{staticClass:\"checkbox\"},[_c('label',[_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.checked),expression:\"checked\"}],ref:\"checkbox\",attrs:{\"type\":\"checkbox\",\"disabled\":_vm.disabled},domProps:{\"checked\":Array.isArray(_vm.checked)?_vm._i(_vm.checked,null)>-1:(_vm.checked)},on:{\"change\":function($event){var $$a=_vm.checked,$$el=$event.target,$$c=$$el.checked?(true):(false);if(Array.isArray($$a)){var $$v=null,$$i=_vm._i($$a,$$v);if($$el.checked){$$i<0&&(_vm.checked=$$a.concat([$$v]))}else{$$i>-1&&(_vm.checked=$$a.slice(0,$$i).concat($$a.slice($$i+1)))}}else{_vm.checked=$$c}}}}),_vm._t(\"default\")],2)]):_c('label',{staticClass:\"checkbox-inline\"},[_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.checked),expression:\"checked\"}],ref:\"checkbox\",attrs:{\"type\":\"checkbox\",\"disabled\":_vm.disabled},domProps:{\"checked\":Array.isArray(_vm.checked)?_vm._i(_vm.checked,null)>-1:(_vm.checked)},on:{\"change\":function($event){var $$a=_vm.checked,$$el=$event.target,$$c=$$el.checked?(true):(false);if(Array.isArray($$a)){var $$v=null,$$i=_vm._i($$a,$$v);if($$el.checked){$$i<0&&(_vm.checked=$$a.concat([$$v]))}else{$$i>-1&&(_vm.checked=$$a.slice(0,$$i).concat($$a.slice($$i+1)))}}else{_vm.checked=$$c}}}}),_vm._t(\"default\")],2)]),_vm._t(\"label\",null,{\"slot\":\"label\"}),(_vm.$slots.description)?_vm._t(\"description\",null,{\"slot\":\"description\"}):_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./BsCheckbox.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!./BsCheckbox.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./BsCheckbox.vue?vue&type=template&id=ca14c080&scoped=true&lang=html&\"\nimport script from \"./BsCheckbox.vue?vue&type=script&lang=js&\"\nexport * from \"./BsCheckbox.vue?vue&type=script&lang=js&\"\nimport style0 from \"./BsCheckbox.vue?vue&type=style&index=0&id=ca14c080&lang=scss&scoped=true&\"\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 \"ca14c080\",\n null\n \n)\n\nexport default component.exports","/**\n * Callback for coordEach\n *\n * @private\n * @callback coordEachCallback\n * @param {[number, number]} currentCoords The current coordinates being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentCoords, currentIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordEach(features, function (currentCoords, currentIndex) {\n * //=currentCoords\n * //=currentIndex\n * });\n */\nfunction coordEach(layer, callback, excludeWrapCoord) {\n var i, j, k, g, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n currentIndex = 0,\n isGeometryCollection,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n coords = geometry.coordinates;\n\n wrapShrink = (excludeWrapCoord &&\n (geometry.type === 'Polygon' || geometry.type === 'MultiPolygon')) ?\n 1 : 0;\n\n if (geometry.type === 'Point') {\n callback(coords, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'LineString' || geometry.type === 'MultiPoint') {\n for (j = 0; j < coords.length; j++) {\n callback(coords[j], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'Polygon' || geometry.type === 'MultiLineString') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n callback(coords[j][k], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'MultiPolygon') {\n for (j = 0; j < coords.length; j++)\n for (k = 0; k < coords[j].length; k++)\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n callback(coords[j][k][l], currentIndex);\n currentIndex++;\n }\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++)\n coordEach(geometry.geometries[j], callback, excludeWrapCoord);\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.coordEach = coordEach;\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {[number, number]} currentCoords The current coordinate being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoords, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include\n * the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.coordReduce(features, function (previousValue, currentCoords, currentIndex) {\n * //=previousValue\n * //=currentCoords\n * //=currentIndex\n * return currentCoords;\n * });\n */\nfunction coordReduce(layer, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(layer, function (currentCoords, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentCoords;\n } else {\n previousValue = callback(previousValue, currentCoords, currentIndex);\n }\n }, excludeWrapCoord);\n return previousValue;\n}\nmodule.exports.coordReduce = coordReduce;\n\n/**\n * Callback for propEach\n *\n * @private\n * @callback propEachCallback\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propEach(features, function (currentProperties, currentIndex) {\n * //=currentProperties\n * //=currentIndex\n * });\n */\nfunction propEach(layer, callback) {\n var i;\n switch (layer.type) {\n case 'FeatureCollection':\n for (i = 0; i < layer.features.length; i++) {\n callback(layer.features[i].properties, i);\n }\n break;\n case 'Feature':\n callback(layer.properties, 0);\n break;\n }\n}\nmodule.exports.propEach = propEach;\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current properties being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.propReduce(features, function (previousValue, currentProperties, currentIndex) {\n * //=previousValue\n * //=currentProperties\n * //=currentIndex\n * return currentProperties\n * });\n */\nfunction propReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n propEach(layer, function (currentProperties, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentProperties;\n } else {\n previousValue = callback(previousValue, currentProperties, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.propReduce = propReduce;\n\n/**\n * Callback for featureEach\n *\n * @private\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureEach(features, function (currentFeature, currentIndex) {\n * //=currentFeature\n * //=currentIndex\n * });\n */\nfunction featureEach(layer, callback) {\n if (layer.type === 'Feature') {\n callback(layer, 0);\n } else if (layer.type === 'FeatureCollection') {\n for (var i = 0; i < layer.features.length; i++) {\n callback(layer.features[i], i);\n }\n }\n}\nmodule.exports.featureEach = featureEach;\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.featureReduce(features, function (previousValue, currentFeature, currentIndex) {\n * //=previousValue\n * //=currentFeature\n * //=currentIndex\n * return currentFeature\n * });\n */\nfunction featureReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(layer, function (currentFeature, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentFeature;\n } else {\n previousValue = callback(previousValue, currentFeature, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.featureReduce = featureReduce;\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {Object} layer any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * var coords = turf.coordAll(features);\n * //=coords\n */\nfunction coordAll(layer) {\n var coords = [];\n coordEach(layer, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\nmodule.exports.coordAll = coordAll;\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, currentIndex)\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomEach(features, function (currentGeometry, currentIndex) {\n * //=currentGeometry\n * //=currentIndex\n * });\n */\nfunction geomEach(layer, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n currentIndex = 0,\n isFeatureCollection = layer.type === 'FeatureCollection',\n isFeature = layer.type === 'Feature',\n stop = isFeatureCollection ? layer.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? layer.features[i].geometry :\n (isFeature ? layer.geometry : layer));\n isGeometryCollection = geometryMaybeCollection.type === 'GeometryCollection';\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n if (geometry.type === 'Point' ||\n geometry.type === 'LineString' ||\n geometry.type === 'MultiPoint' ||\n geometry.type === 'Polygon' ||\n geometry.type === 'MultiLineString' ||\n geometry.type === 'MultiPolygon') {\n callback(geometry, currentIndex);\n currentIndex++;\n } else if (geometry.type === 'GeometryCollection') {\n for (j = 0; j < geometry.geometries.length; j++) {\n callback(geometry.geometries[j], currentIndex);\n currentIndex++;\n }\n } else {\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\nmodule.exports.geomEach = geomEach;\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @private\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentGeometry The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {Object} layer any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"foo\": \"bar\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [26, 37]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {\"hello\": \"world\"},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [36, 53]\n * }\n * }\n * ]\n * };\n * turf.geomReduce(features, function (previousValue, currentGeometry, currentIndex) {\n * //=previousValue\n * //=currentGeometry\n * //=currentIndex\n * return currentGeometry\n * });\n */\nfunction geomReduce(layer, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(layer, function (currentGeometry, currentIndex) {\n if (currentIndex === 0 && initialValue === undefined) {\n previousValue = currentGeometry;\n } else {\n previousValue = callback(previousValue, currentGeometry, currentIndex);\n }\n });\n return previousValue;\n}\nmodule.exports.geomReduce = geomReduce;\n","var meta = require('@turf/meta');\nvar getCoords = require('@turf/invariant').getCoords;\nvar booleanClockwise = require('@turf/boolean-clockwise');\nvar featureCollection = require('@turf/helpers').featureCollection;\nvar geomEach = meta.geomEach;\nvar featureEach = meta.featureEach;\n\n/**\n * Rewind {@link LineString|(Multi)LineString} or {@link Polygon|(Multi)Polygon} outer ring counterclockwise and inner rings clockwise (Uses {@link http://en.wikipedia.org/wiki/Shoelace_formula|Shoelace Formula}).\n *\n * @name rewind\n * @param {FeatureCollection|Geometry|Feature} geojson input GeoJSON Polygon\n * @param {Boolean} [reverse=false] enable reverse winding\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {FeatureCollection|Geometry|Feature} rewind Polygon\n * @example\n * var polygon = turf.polygon([[[121, -29], [138, -29], [138, -18], [121, -18], [121, -29]]]);\n *\n * var rewind = turf.rewind(polygon);\n *\n * //addToMap\n * var addToMap = [rewind];\n */\nmodule.exports = function (geojson, reverse, mutate) {\n // default params\n reverse = (reverse !== undefined) ? reverse : false;\n mutate = (mutate !== undefined) ? mutate : false;\n\n // validation\n if (!geojson) throw new Error(' is required');\n if (typeof reverse !== 'boolean') throw new Error(' must be a boolean');\n if (typeof mutate !== 'boolean') throw new Error(' must be a boolean');\n\n // prevent input mutation\n if (mutate === false || mutate === undefined) geojson = JSON.parse(JSON.stringify(geojson));\n\n // Support Feature Collection or Geometry Collection\n var results = [];\n switch (geojson.type) {\n case 'GeometryCollection':\n geomEach(geojson, function (geometry) {\n rewind(geometry, reverse);\n });\n return geojson;\n case 'FeatureCollection':\n featureEach(geojson, function (feature) {\n featureEach(rewind(feature, reverse), function (result) {\n results.push(result);\n });\n });\n return featureCollection(results);\n }\n // Support Feature or Geometry Objects\n return rewind(geojson, reverse);\n};\n\n/**\n * Rewind\n *\n * @private\n * @param {Geometry|Feature} geojson Geometry or Feature\n * @param {Boolean} [reverse=false] enable reverse winding\n * @returns {Geometry|Feature} rewind Geometry or Feature\n */\nfunction rewind(geojson, reverse) {\n var type = (geojson.type === 'Feature') ? geojson.geometry.type : geojson.type;\n\n // Support all GeoJSON Geometry Objects\n switch (type) {\n case 'GeometryCollection':\n geomEach(geojson, function (geometry) {\n rewind(geometry, reverse);\n });\n return geojson;\n case 'LineString':\n rewindLineString(getCoords(geojson), reverse);\n return geojson;\n case 'Polygon':\n rewindPolygon(getCoords(geojson), reverse);\n return geojson;\n case 'MultiLineString':\n getCoords(geojson).forEach(function (lineCoords) {\n rewindLineString(lineCoords, reverse);\n });\n return geojson;\n case 'MultiPolygon':\n getCoords(geojson).forEach(function (lineCoords) {\n rewindPolygon(lineCoords, reverse);\n });\n return geojson;\n case 'Point':\n case 'MultiPoint':\n return geojson;\n }\n}\n\n/**\n * Rewind LineString - outer ring clockwise\n *\n * @private\n * @param {Array>} coords GeoJSON LineString geometry coordinates\n * @param {Boolean} [reverse=false] enable reverse winding\n * @returns {void} mutates coordinates\n */\nfunction rewindLineString(coords, reverse) {\n if (booleanClockwise(coords) === reverse) coords.reverse();\n}\n\n/**\n * Rewind Polygon - outer ring counterclockwise and inner rings clockwise.\n *\n * @private\n * @param {Array>>} coords GeoJSON Polygon geometry coordinates\n * @param {Boolean} [reverse=false] enable reverse winding\n * @returns {void} mutates coordinates\n */\nfunction rewindPolygon(coords, reverse) {\n // outer ring\n if (booleanClockwise(coords[0]) !== reverse) {\n coords[0].reverse();\n }\n // inner rings\n for (var i = 1; i < coords.length; i++) {\n if (booleanClockwise(coords[i]) === reverse) {\n coords[i].reverse();\n }\n }\n}\n","/*!\n* MarchingSquaresJS\n* version 1.3.2\n* https://github.com/RaumZeit/MarchingSquares.js\n*\n* @license GNU Affero General Public License.\n* Copyright (c) 2015-2018 Ronny Lorenz \n*/\n\n\n/*\n * Compute the distance of a value 'v' from 'a' through linear interpolation\n * between the values of 'a' and 'b'\n *\n * Note, that we assume that 'a' and 'b' have unit distance (i.e. 1)\n */\nfunction linear(a, b, v) {\n if (a < b)\n return (v - a) / (b - a);\n\n return (a - v) / (a - b);\n}\n\n\n/*\n * Compute the distance of a pair of values ('v0', 'v1') from 'a' through linear interpolation\n * between the values of 'a' and 'b'\n *\n * This function assumes that exactly one value, 'v0' or 'v1', is actually located\n * between 'a' and 'b', and choses the right one automagically\n *\n * Note, that we assume that 'a' and 'b' have unit distance (i.e. 1)\n */\nfunction linear_ab(a, b, v0, v1) {\n var tmp;\n\n if (v0 > v1) {\n tmp = v0;\n v0 = v1;\n v1 = tmp;\n }\n\n if (a < b) {\n if (a < v0)\n return (v0 - a) / (b - a);\n else\n return (v1 - a) / (b - a);\n } else if (a > v1) {\n return (a - v1) / (a - b);\n }\n\n return (a - v0) / (a - b);\n}\n\n\n/*\n * Compute the distance of a pair of values ('v0', 'v1') from 'a' through linear interpolation\n * between the values of 'a' and 'b'\n *\n * This function automagically choses the value 'vN' that is closer to 'a'\n *\n * Note, that we assume that 'a' and 'b' have unit distance (i.e. 1)\n */\nfunction linear_a(a, b, minV, maxV) {\n if (a < b)\n return (minV - a) / (b - a);\n\n return (a - maxV) / (a - b);\n}\n\n\n/*\n * Compute the distance of a pair of values ('v0', 'v1') from 'a' through linear interpolation\n * between the values of 'a' and 'b'\n *\n * This function automagically choses the value 'vN' that is closer to 'b'\n *\n * Note, that we assume that 'a' and 'b' have unit distance (i.e. 1)\n */\nfunction linear_b(a, b, minV, maxV) {\n if (a < b)\n return (maxV - a) / (b - a);\n\n return (a - minV) / (a - b);\n}\n\nfunction Options() {\n /* Settings common to all implemented algorithms */\n this.successCallback = null;\n this.verbose = false;\n this.polygons = false;\n this.polygons_full = false;\n this.linearRing = true;\n this.noQuadTree = false;\n}\n\n\n/* Compose settings specific to IsoBands algorithm */\nfunction isoBandOptions(userSettings) {\n var i,\n key,\n val,\n bandOptions,\n optionKeys;\n\n bandOptions = new Options();\n userSettings = userSettings ? userSettings : {};\n optionKeys = Object.keys(bandOptions);\n\n for(i = 0; i < optionKeys.length; i++) {\n key = optionKeys[i];\n val = userSettings[key];\n if ((typeof val !== 'undefined') && (val !== null))\n bandOptions[key] = val;\n }\n\n /* restore compatibility */\n bandOptions.polygons_full = !bandOptions.polygons;\n\n /* add interpolation functions (not yet user customizable) */\n bandOptions.interpolate = linear_ab;\n bandOptions.interpolate_a = linear_a;\n bandOptions.interpolate_b = linear_b;\n\n return bandOptions;\n}\n\n\n/* Compose settings specific to IsoLines algorithm */\nfunction isoLineOptions(userSettings) {\n var i,\n key,\n val,\n lineOptions,\n optionKeys;\n\n lineOptions = new Options();\n userSettings = userSettings ? userSettings : {};\n optionKeys = Object.keys(lineOptions);\n\n for(i = 0; i < optionKeys.length; i++) {\n key = optionKeys[i];\n val = userSettings[key];\n if ((typeof val !== 'undefined') && (val !== null))\n lineOptions[key] = val;\n }\n\n /* restore compatibility */\n lineOptions.polygons_full = !lineOptions.polygons;\n\n /* add interpolation functions (not yet user customizable) */\n lineOptions.interpolate = linear;\n\n return lineOptions;\n}\n\nfunction cell2Polygons(cell, x, y, settings) {\n var polygons = [];\n\n cell.polygons.forEach(function(p) {\n p.forEach(function(pp) {\n pp[0] += x;\n pp[1] += y;\n });\n\n if (settings.linearRing)\n p.push(p[0]);\n\n polygons.push(p);\n });\n\n return polygons;\n}\n\nfunction entry_coordinate(x, y, mode, path) {\n if (mode === 0) { /* down */\n x += 1;\n y += path[0][1];\n } else if (mode === 1) { /* left */\n x += path[0][0];\n } else if (mode === 2) { /* up */\n y += path[0][1];\n } else if (mode === 3) { /* right */\n x += path[0][0];\n y += 1;\n }\n\n return [ x, y ];\n}\n\n\nfunction skip_coordinate(x, y, mode) {\n if (mode === 0) { /* down */\n x++;\n } else if (mode === 1) ; else if (mode === 2) { /* up */\n y++;\n } else if (mode === 3) { /* right */\n x++;\n y++;\n }\n\n return [ x, y ];\n}\n\n\nfunction requireFrame(data, lowerBound, upperBound) {\n var frameRequired,\n cols,\n rows,\n i,\n j;\n\n frameRequired = true;\n cols = data[0].length;\n rows = data.length;\n\n for (j = 0; j < rows; j++) {\n if ((data[j][0] < lowerBound) ||\n (data[j][0] > upperBound) ||\n (data[j][cols - 1] < lowerBound) ||\n (data[j][cols - 1] > upperBound)) {\n frameRequired = false;\n break;\n }\n }\n\n if ((frameRequired) &&\n ((data[rows - 1][0] < lowerBound) ||\n (data[rows - 1][0] > upperBound) ||\n (data[rows - 1][cols - 1] < lowerBound) ||\n (data[rows - 1][cols - 1] > upperBound))) {\n frameRequired = false;\n }\n\n if (frameRequired)\n for (i = 0; i < cols - 1; i++) {\n if ((data[0][i] < lowerBound) ||\n (data[0][i] > upperBound) ||\n (data[rows - 1][i] < lowerBound) ||\n (data[rows - 1][i] > upperBound)) {\n frameRequired = false;\n break;\n }\n }\n\n\n return frameRequired;\n}\n\n\nfunction requireLineFrame(data, threshold) {\n var frameRequired,\n cols,\n rows,\n i,\n j;\n\n frameRequired = true;\n cols = data[0].length;\n rows = data.length;\n\n for (j = 0; j < rows; j++) {\n if ((data[j][0] >= threshold) ||\n (data[j][cols - 1] >= threshold)) {\n frameRequired = false;\n break;\n }\n }\n\n if ((frameRequired) &&\n ((data[rows - 1][0] >= threshold) ||\n (data[rows - 1][cols - 1] >= threshold))) {\n frameRequired = false;\n }\n\n if (frameRequired)\n for (i = 0; i < cols - 1; i++) {\n if ((data[0][i] >= threshold) ||\n (data[rows - 1][i] > threshold)) {\n frameRequired = false;\n break;\n }\n }\n\n return frameRequired;\n}\n\n\nfunction traceBandPaths(data, cellGrid, settings) {\n var nextedge,\n path,\n e,\n ee,\n s,\n ve,\n enter,\n x,\n y,\n finalized,\n origin,\n cc,\n dir,\n count,\n point,\n found_entry;\n\n var polygons = [];\n var rows = data.length - 1;\n var cols = data[0].length - 1;\n\n /*\n * directions for out-of-grid moves are:\n * 0 ... \"down\",\n * 1 ... \"left\",\n * 2 ... \"up\",\n * 3 ... \"right\"\n */\n var valid_entries = [ ['rt', 'rb'], /* down */\n ['br', 'bl'], /* left */\n ['lb', 'lt'], /* up */\n ['tl', 'tr'] /* right */\n ];\n var add_x = [ 0, -1, 0, 1 ];\n var add_y = [ -1, 0, 1, 0 ];\n var available_starts = [ 'bl', 'lb', 'lt', 'tl', 'tr', 'rt', 'rb', 'br' ];\n var entry_dir = {\n bl: 1, br: 1,\n lb: 2, lt: 2,\n tl: 3, tr: 3,\n rt: 0, rb: 0\n };\n\n if (requireFrame(data, settings.minV, settings.maxV)) {\n if (settings.linearRing)\n polygons.push([ [0, 0], [0, rows], [cols, rows], [cols, 0], [0, 0] ]);\n else\n polygons.push([ [0, 0], [0, rows], [cols, rows], [cols, 0] ]);\n }\n\n /* finally, start tracing back first polygon(s) */\n cellGrid.forEach(function(a, i) {\n a.forEach(function(cell, j) {\n nextedge = null;\n\n /* trace paths for all available edges that go through this cell */\n for (e = 0; e < 8; e++) {\n nextedge = available_starts[e];\n\n if (typeof cell.edges[nextedge] !== 'object')\n continue;\n\n /* start a new, full path */\n path = [];\n ee = cell.edges[nextedge];\n enter = nextedge;\n x = i;\n y = j;\n finalized = false;\n origin = [ i + ee.path[0][0], j + ee.path[0][1] ];\n\n /* add start coordinate */\n path.push(origin);\n\n /* start traceback */\n while (!finalized) {\n cc = cellGrid[x][y];\n\n if (typeof cc.edges[enter] !== 'object')\n break;\n\n ee = cc.edges[enter];\n\n /* remove edge from cell */\n delete cc.edges[enter];\n\n /* add last point of edge to path arra, since we extend a polygon */\n point = ee.path[1];\n point[0] += x;\n point[1] += y;\n path.push(point);\n\n enter = ee.move.enter;\n x = x + ee.move.x;\n y = y + ee.move.y;\n\n /* handle out-of-grid moves */\n if ((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined')) {\n dir = 0;\n count = 0;\n\n if (x === cols) {\n x--;\n dir = 0; /* move downwards */\n } else if (x < 0) {\n x++;\n dir = 2; /* move upwards */\n } else if (y === rows) {\n y--;\n dir = 3; /* move right */\n } else if (y < 0) {\n y++;\n dir = 1; /* move left */\n } else {\n throw new Error('Left the grid somewhere in the interior!');\n }\n\n if ((x === i) && (y === j) && (dir === entry_dir[nextedge])) {\n finalized = true;\n enter = nextedge;\n break;\n }\n\n while (1) {\n found_entry = false;\n\n if (count > 4)\n throw new Error('Direction change counter overflow! This should never happen!');\n\n if (!((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined'))) {\n cc = cellGrid[x][y];\n\n /* check for re-entry */\n for (s = 0; s < valid_entries[dir].length; s++) {\n ve = valid_entries[dir][s];\n if (typeof cc.edges[ve] === 'object') {\n /* found re-entry */\n ee = cc.edges[ve];\n path.push(entry_coordinate(x, y, dir, ee.path));\n enter = ve;\n found_entry = true;\n break;\n }\n }\n }\n\n if (found_entry) {\n break;\n } else {\n path.push(skip_coordinate(x, y, dir));\n\n x += add_x[dir];\n y += add_y[dir];\n\n /* change direction if we'e moved out of grid again */\n if ((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined')) {\n if (((dir === 0) && (y < 0)) ||\n ((dir === 1) && (x < 0)) ||\n ((dir === 2) && (y === rows)) ||\n ((dir === 3) && (x === cols))) {\n x -= add_x[dir];\n y -= add_y[dir];\n\n dir = (dir + 1) % 4;\n count++;\n }\n }\n\n if ((x === i) && (y === j) && (dir === entry_dir[nextedge])) {\n /* we are back where we started off, so finalize the polygon */\n finalized = true;\n enter = nextedge;\n break;\n }\n }\n }\n }\n }\n\n if ((settings.linearRing) &&\n ((path[path.length - 1][0] !== origin[0]) ||\n (path[path.length - 1][1] !== origin[1])))\n path.push(origin);\n\n polygons.push(path);\n } /* end forall entry sites */\n }); /* end foreach i */\n }); /* end foreach j */\n\n return polygons;\n}\n\n\nfunction traceLinePaths(data, cellGrid, settings) {\n var nextedge,\n e,\n ee,\n cc,\n path,\n enter,\n x,\n y,\n finalized,\n origin,\n point,\n dir,\n count,\n found_entry,\n ve;\n\n var polygons = [];\n var rows = data.length - 1;\n var cols = data[0].length - 1;\n\n /*\n * directions for out-of-grid moves are:\n * 0 ... \"down\",\n * 1 ... \"left\",\n * 2 ... \"up\",\n * 3 ... \"right\"\n */\n var valid_entries = [ 'right', /* down */\n 'bottom', /* left */\n 'left', /* up */\n 'top' /* right */\n ];\n var add_x = [ 0, -1, 0, 1 ];\n var add_y = [ -1, 0, 1, 0 ];\n var entry_dir = {\n bottom: 1,\n left: 2,\n top: 3,\n right: 0\n };\n\n /* first, detect whether we need any outer frame */\n if (requireLineFrame(data, settings.threshold)) {\n if (settings.linearRing)\n polygons.push([ [0, 0], [0, rows], [cols, rows], [cols, 0], [0, 0] ]);\n else\n polygons.push([ [0, 0], [0, rows], [cols, rows], [cols, 0] ]);\n }\n\n /* finally, start tracing back first polygon(s) */\n\n cellGrid.forEach(function(a, i) {\n a.forEach(function(cell, j) {\n nextedge = null;\n\n /* trace paths for all available edges that go through this cell */\n for (e = 0; e < 4; e++) {\n nextedge = valid_entries[e];\n\n if (typeof cell.edges[nextedge] !== 'object')\n continue;\n\n /* start a new, full path */\n path = [];\n ee = cell.edges[nextedge];\n enter = nextedge;\n x = i;\n y = j;\n finalized = false;\n origin = [ i + ee.path[0][0], j + ee.path[0][1] ];\n\n /* add start coordinate */\n path.push(origin);\n\n /* start traceback */\n while (!finalized) {\n cc = cellGrid[x][y];\n\n if (typeof cc.edges[enter] !== 'object')\n break;\n\n ee = cc.edges[enter];\n\n /* remove edge from cell */\n delete cc.edges[enter];\n\n /* add last point of edge to path arra, since we extend a polygon */\n point = ee.path[1];\n point[0] += x;\n point[1] += y;\n path.push(point);\n\n enter = ee.move.enter;\n x = x + ee.move.x;\n y = y + ee.move.y;\n\n /* handle out-of-grid moves */\n if ((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined')) {\n\n if (!settings.linearRing)\n break;\n\n dir = 0;\n count = 0;\n\n if (x === cols) {\n x--;\n dir = 0; /* move downwards */\n } else if (x < 0) {\n x++;\n dir = 2; /* move upwards */\n } else if (y === rows) {\n y--;\n dir = 3; /* move right */\n } else if (y < 0) {\n y++;\n dir = 1; /* move left */\n }\n\n if ((x === i) && (y === j) && (dir === entry_dir[nextedge])) {\n finalized = true;\n enter = nextedge;\n break;\n }\n\n while (1) {\n found_entry = false;\n\n if (count > 4)\n throw new Error('Direction change counter overflow! This should never happen!');\n\n if (!((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined'))) {\n cc = cellGrid[x][y];\n\n /* check for re-entry */\n ve = valid_entries[dir];\n if (typeof cc.edges[ve] === 'object') {\n /* found re-entry */\n ee = cc.edges[ve];\n path.push(entry_coordinate(x, y, dir, ee.path));\n enter = ve;\n found_entry = true;\n break;\n }\n }\n\n if (found_entry) {\n break;\n } else {\n path.push(skip_coordinate(x, y, dir));\n\n x += add_x[dir];\n y += add_y[dir];\n\n /* change direction if we'e moved out of grid again */\n if ((typeof cellGrid[x] === 'undefined') ||\n (typeof cellGrid[x][y] === 'undefined')) {\n if (((dir === 0) && (y < 0)) ||\n ((dir === 1) && (x < 0)) ||\n ((dir === 2) && (y === rows)) ||\n ((dir === 3) && (x === cols))) {\n x -= add_x[dir];\n y -= add_y[dir];\n\n dir = (dir + 1) % 4;\n count++;\n }\n }\n\n if ((x === i) && (y === j) && (dir === entry_dir[nextedge])) {\n /* we are back where we started off, so finalize the polygon */\n finalized = true;\n enter = nextedge;\n break;\n }\n }\n }\n }\n }\n\n if ((settings.linearRing) &&\n ((path[path.length - 1][0] !== origin[0]) ||\n (path[path.length - 1][1] !== origin[1])))\n path.push(origin);\n\n polygons.push(path);\n } /* end forall entry sites */\n }); /* end foreach i */\n }); /* end foreach j */\n\n return polygons;\n}\n\n/* quadTree node constructor */\nfunction TreeNode(data, x, y, dx, dy) {\n var dx_tmp = dx,\n dy_tmp = dy,\n msb_x = 0,\n msb_y = 0;\n\n /* left-bottom corner of current quadrant */\n this.x = x;\n this.y = y;\n\n /* minimum value in subtree under this node */\n this.lowerBound = null;\n /* maximum value in subtree under this node */\n this.upperBound = null;\n\n /*\n * child nodes are layed out in the following way:\n *\n * (x, y + 1) ---- (x + 1, y + 1)\n * | | |\n * | D | C |\n * | | |\n * |----------------------------|\n * | | |\n * | A | B |\n * | | |\n * (x, y) ------------ (x + 1, y)\n */\n this.childA = null;\n this.childB = null;\n this.childC = null;\n this.childD = null;\n\n if ((dx === 1) && (dy === 1)) {\n /* do not further subdivision */\n this.lowerBound = Math.min(\n data[y][x],\n data[y][x + 1],\n data[y + 1][x + 1],\n data[y + 1][x]\n );\n this.upperBound = Math.max(\n data[y][x],\n data[y][x + 1],\n data[y + 1][x + 1],\n data[y + 1][x]\n );\n } else {\n /* get most significant bit from dx */\n if (dx > 1) {\n while (dx_tmp !== 0) {\n dx_tmp = dx_tmp >> 1;\n msb_x++;\n }\n\n if (dx === (1 << (msb_x - 1)))\n msb_x--;\n\n dx_tmp = 1 << (msb_x - 1);\n }\n\n /* get most significant bit from dx */\n if (dy > 1) {\n while (dy_tmp !== 0) {\n dy_tmp = dy_tmp >> 1;\n msb_y++;\n }\n\n if (dy === (1 << (msb_y - 1)))\n msb_y--;\n\n dy_tmp = 1 << (msb_y - 1);\n }\n\n this.childA = new TreeNode(data, x, y, dx_tmp, dy_tmp);\n this.lowerBound = this.childA.lowerBound;\n this.upperBound = this.childA.upperBound;\n\n if (dx - dx_tmp > 0) {\n this.childB = new TreeNode(data, x + dx_tmp, y, dx - dx_tmp, dy_tmp);\n this.lowerBound = Math.min(this.lowerBound, this.childB.lowerBound);\n this.upperBound = Math.max(this.upperBound, this.childB.upperBound);\n\n if (dy - dy_tmp > 0) {\n this.childC = new TreeNode(data, x + dx_tmp, y + dy_tmp, dx - dx_tmp, dy - dy_tmp);\n this.lowerBound = Math.min(this.lowerBound, this.childC.lowerBound);\n this.upperBound = Math.max(this.upperBound, this.childC.upperBound);\n }\n }\n\n if (dy - dy_tmp > 0) {\n this.childD = new TreeNode(data, x, y + dy_tmp, dx_tmp, dy - dy_tmp);\n this.lowerBound = Math.min(this.lowerBound, this.childD.lowerBound);\n this.upperBound = Math.max(this.upperBound, this.childD.upperBound);\n }\n }\n}\n\n\n/**\n * Retrieve a list of cells within a particular range of values by\n * recursivly traversing the quad tree to it's leaves.\n *\n * @param subsumed If 'true' include all cells that are completely\n * subsumed within the specified range. Otherwise,\n * return only cells where at least one corner is\n * outside the specified range.\n *\n * @return An array of objects 'o' where each object has exactly two\n * properties: 'o.x' and 'o.y' denoting the left-bottom corner\n * of the corresponding cell.\n */\nTreeNode.prototype.cellsInBand = function(lowerBound, upperBound, subsumed) {\n var cells = [];\n\n subsumed = (typeof subsumed === 'undefined') ? true : subsumed;\n\n if ((this.lowerBound > upperBound) || (this.upperBound < lowerBound))\n return cells;\n\n if (!(this.childA || this.childB || this.childC || this.childD)) {\n if ((subsumed) ||\n (this.lowerBound <= lowerBound) ||\n (this.upperBound >= upperBound)) {\n cells.push({\n x: this.x,\n y: this.y\n });\n }\n } else {\n if (this.childA)\n cells = cells.concat(this.childA.cellsInBand(lowerBound, upperBound, subsumed));\n\n if (this.childB)\n cells = cells.concat(this.childB.cellsInBand(lowerBound, upperBound, subsumed));\n\n if (this.childD)\n cells = cells.concat(this.childD.cellsInBand(lowerBound, upperBound, subsumed));\n\n if (this.childC)\n cells = cells.concat(this.childC.cellsInBand(lowerBound, upperBound, subsumed));\n }\n\n return cells;\n};\n\n\nTreeNode.prototype.cellsBelowThreshold = function(threshold, subsumed) {\n var cells = [];\n\n subsumed = (typeof subsumed === 'undefined') ? true : subsumed;\n\n if (this.lowerBound > threshold)\n return cells;\n\n if (!(this.childA || this.childB || this.childC || this.childD)) {\n if ((subsumed) ||\n (this.upperBound >= threshold)) {\n cells.push({\n x: this.x,\n y: this.y\n });\n }\n } else {\n if (this.childA)\n cells = cells.concat(this.childA.cellsBelowThreshold(threshold, subsumed));\n\n if (this.childB)\n cells = cells.concat(this.childB.cellsBelowThreshold(threshold, subsumed));\n\n if (this.childD)\n cells = cells.concat(this.childD.cellsBelowThreshold(threshold, subsumed));\n\n if (this.childC)\n cells = cells.concat(this.childC.cellsBelowThreshold(threshold, subsumed));\n }\n\n return cells;\n};\n\n\n/*\n * Given a scalar field `data` construct a QuadTree\n * to efficiently lookup those parts of the scalar\n * field where values are within a particular\n * range of [lowerbound, upperbound] limits.\n */\nfunction QuadTree(data) {\n var i, cols;\n\n /* do some input checking */\n if (!data)\n throw new Error('data is required');\n\n if (!Array.isArray(data) ||\n !Array.isArray(data[0]))\n throw new Error('data must be scalar field, i.e. array of arrays');\n\n if (data.length < 2)\n throw new Error('data must contain at least two rows');\n\n /* check if we've got a regular grid */\n cols = data[0].length;\n\n if (cols < 2)\n throw new Error('data must contain at least two columns');\n\n for (i = 1; i < data.length; i++) {\n if (!Array.isArray(data[i]))\n throw new Error('Row ' + i + ' is not an array');\n\n if (data[i].length != cols)\n throw new Error('unequal row lengths detected, please provide a regular grid');\n }\n\n /* create pre-processing object */\n this.data = data;\n /* root node, i.e. entry to the data */\n this.root = new TreeNode(data, 0, 0, data[0].length - 1, data.length - 1);\n}\n\n/* eslint no-console: [\"error\", { allow: [\"log\"] }] */\n\n\n/*\n * Compute the iso lines for a scalar 2D field given\n * a certain threshold by applying the Marching Squares\n * Algorithm. The function returns a list of path coordinates\n */\n\nfunction isoLines(input, threshold, options) {\n var settings,\n i,\n j,\n useQuadTree = false,\n multiLine = false,\n tree = null,\n root = null,\n data = null,\n cellGrid = null,\n linePolygons = null,\n ret = [];\n\n /* validation */\n if (!input) throw new Error('data is required');\n if (threshold === undefined || threshold === null) throw new Error('threshold is required');\n if ((!!options) && (typeof options !== 'object')) throw new Error('options must be an object');\n\n /* process options */\n settings = isoLineOptions(options);\n\n /* check for input data */\n if (input instanceof QuadTree) {\n tree = input;\n root = input.root;\n data = input.data;\n if (!settings.noQuadTree)\n useQuadTree = true;\n } else if (Array.isArray(input) && Array.isArray(input[0])) {\n data = input;\n } else {\n throw new Error('input is neither array of arrays nor object retrieved from \\'QuadTree()\\'');\n }\n\n /* check and prepare input threshold(s) */\n if (Array.isArray(threshold)) {\n multiLine = true;\n\n /* activate QuadTree optimization if not explicitly forbidden by user settings */\n if (!settings.noQuadTree)\n useQuadTree = true;\n\n /* check if all minV are numbers */\n for (i = 0; i < threshold.length; i++)\n if (isNaN(+threshold[i]))\n throw new Error('threshold[' + i + '] is not a number');\n } else {\n if (isNaN(+threshold))\n throw new Error('threshold must be a number or array of numbers');\n\n threshold = [ threshold ];\n }\n\n /* create QuadTree root node if not already present */\n if ((useQuadTree) && (!root)) {\n tree = new QuadTree(data);\n root = tree.root;\n data = tree.data;\n }\n\n if (settings.verbose) {\n if(settings.polygons)\n console.log('MarchingSquaresJS-isoLines: returning single lines (polygons) for each grid cell');\n else\n console.log('MarchingSquaresJS-isoLines: returning line paths (polygons) for entire data grid');\n\n if (multiLine)\n console.log('MarchingSquaresJS-isoLines: multiple lines requested, returning array of line paths instead of lines for a single threshold');\n }\n\n /* Done with all input validation, now let's start computing stuff */\n\n /* loop over all threhsold values */\n threshold.forEach(function(t, i) {\n linePolygons = [];\n\n /* store bounds for current computation in settings object */\n settings.threshold = t;\n\n if(settings.verbose)\n console.log('MarchingSquaresJS-isoLines: computing iso lines for threshold ' + t);\n\n if (settings.polygons) {\n /* compose list of polygons for each single cell */\n if (useQuadTree) {\n /* go through list of cells retrieved from QuadTree */\n root\n .cellsBelowThreshold(settings.threshold, true)\n .forEach(function(c) {\n linePolygons = linePolygons.concat(\n cell2Polygons(\n prepareCell(data,\n c.x,\n c.y,\n settings),\n c.x,\n c.y,\n settings\n ));\n });\n } else {\n /* go through entire array of input data */\n for (j = 0; j < data.length - 1; ++j) {\n for (i = 0; i < data[0].length - 1; ++i)\n linePolygons = linePolygons.concat(\n cell2Polygons(\n prepareCell(data,\n i,\n j,\n settings),\n i,\n j,\n settings\n ));\n }\n }\n } else {\n /* sparse grid of input data cells */\n cellGrid = [];\n for (i = 0; i < data[0].length - 1; ++i)\n cellGrid[i] = [];\n\n /* compose list of polygons for entire input grid */\n if (useQuadTree) {\n /* collect the cells */\n root\n .cellsBelowThreshold(settings.threshold, false)\n .forEach(function(c) {\n cellGrid[c.x][c.y] = prepareCell(data,\n c.x,\n c.y,\n settings);\n });\n } else {\n /* prepare cells */\n for (i = 0; i < data[0].length - 1; ++i) {\n for (j = 0; j < data.length - 1; ++j) {\n cellGrid[i][j] = prepareCell(data,\n i,\n j,\n settings);\n }\n }\n }\n\n linePolygons = traceLinePaths(data, cellGrid, settings);\n }\n\n /* finally, add polygons to output array */\n if (multiLine)\n ret.push(linePolygons);\n else\n ret = linePolygons;\n\n if(typeof settings.successCallback === 'function')\n settings.successCallback(ret, t);\n\n });\n\n return ret;\n}\n\n/*\n * Thats all for the public interface, below follows the actual\n * implementation\n */\n\n/*\n * ################################\n * Isocontour implementation below\n * ################################\n */\n\nfunction prepareCell(grid, x, y, settings) {\n var left,\n right,\n top,\n bottom,\n average,\n cell;\n\n var cval = 0;\n var x3 = grid[y + 1][x];\n var x2 = grid[y + 1][x + 1];\n var x1 = grid[y][x + 1];\n var x0 = grid[y][x];\n var threshold = settings.threshold;\n\n /*\n * Note that missing data within the grid will result\n * in horribly failing to trace full polygon paths\n */\n if(isNaN(x0) || isNaN(x1) || isNaN(x2) || isNaN(x3)) {\n return;\n }\n\n /*\n * Here we detect the type of the cell\n *\n * x3 ---- x2\n * | |\n * | |\n * x0 ---- x1\n *\n * with edge points\n *\n * x0 = (x,y),\n * x1 = (x + 1, y),\n * x2 = (x + 1, y + 1), and\n * x3 = (x, y + 1)\n *\n * and compute the polygon intersections with the edges\n * of the cell. Each edge value may be (i) smaller, or (ii)\n * greater or equal to the iso line threshold. We encode\n * this property using 1 bit of information, where\n *\n * 0 ... below,\n * 1 ... above or equal\n *\n * Then we store the cells value as vector\n *\n * cval = (x0, x1, x2, x3)\n *\n * where x0 is the least significant bit (0th),\n * x1 the 2nd bit, and so on. This essentially\n * enables us to work with a single integer number\n */\n\n cval |= ((x3 >= threshold) ? 8 : 0);\n cval |= ((x2 >= threshold) ? 4 : 0);\n cval |= ((x1 >= threshold) ? 2 : 0);\n cval |= ((x0 >= threshold) ? 1 : 0);\n\n /* make sure cval is a number */\n cval = +cval;\n\n /* compose the cell object */\n cell = {\n cval: cval,\n polygons: [],\n edges: {},\n x0: x0,\n x1: x1,\n x2: x2,\n x3: x3\n };\n\n /*\n * Compute interpolated intersections of the polygon(s)\n * with the cell borders and (i) add edges for polygon\n * trace-back, or (ii) a list of small closed polygons\n */\n switch (cval) {\n case 0:\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [1, 1], [1, 0] ]);\n\n break;\n\n case 15:\n /* cell is outside (above) threshold, no polygons */\n break;\n\n case 14: /* 1110 */\n left = settings.interpolate(x0, x3, threshold);\n bottom = settings.interpolate(x0, x1, threshold);\n\n if (settings.polygons_full) {\n cell.edges.left = {\n path: [ [0, left], [bottom, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'top'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, left], [bottom, 0] ]);\n\n break;\n\n case 13: /* 1101 */\n bottom = settings.interpolate(x0, x1, threshold);\n right = settings.interpolate(x1, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.bottom = {\n path: [ [bottom, 0], [1, right] ],\n move: {\n x: 1,\n y: 0,\n enter: 'left'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [bottom, 0], [1, right], [1, 0] ]);\n\n break;\n\n case 11: /* 1011 */\n right = settings.interpolate(x1, x2, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.right = {\n path: [ [1, right], [top, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bottom'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [1, right], [top, 1], [1, 1] ]);\n\n break;\n\n case 7: /* 0111 */\n left = settings.interpolate(x0, x3, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.top = {\n path: [ [top, 1], [0, left] ],\n move: {\n x: -1,\n y: 0,\n enter: 'right'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [top, 1], [0, left], [0, 1] ]);\n\n break;\n\n case 1: /* 0001 */\n left = settings.interpolate(x0, x3, threshold);\n bottom = settings.interpolate(x0, x1, threshold);\n\n if (settings.polygons_full) {\n cell.edges.bottom = {\n path: [ [bottom, 0], [0, left] ],\n move: {\n x: -1,\n y: 0,\n enter: 'right'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [bottom, 0], [0, left], [0, 1], [1, 1], [1, 0] ]);\n\n break;\n\n case 2: /* 0010 */\n bottom = settings.interpolate(x0, x1, threshold);\n right = settings.interpolate(x1, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.right = {\n path: [ [1, right], [bottom, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'top'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [1, 1], [1, right], [bottom, 0] ]);\n\n break;\n\n case 4: /* 0100 */\n right = settings.interpolate(x1, x2, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.top = {\n path: [ [top, 1], [1, right] ],\n move: {\n x: 1,\n y: 0,\n enter: 'left'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [top, 1], [1, right], [1, 0] ]);\n\n break;\n\n case 8: /* 1000 */\n left = settings.interpolate(x0, x3, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.left = {\n path: [ [0, left], [top, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bottom'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, left], [top, 1], [1, 1], [1, 0] ]);\n\n break;\n\n case 12: /* 1100 */\n left = settings.interpolate(x0, x3, threshold);\n right = settings.interpolate(x1, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.left = {\n path: [ [0, left], [1, right] ],\n move: {\n x: 1,\n y: 0,\n enter: 'left'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, left], [1, right], [1, 0] ]);\n\n break;\n\n case 9: /* 1001 */\n bottom = settings.interpolate(x0, x1, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.bottom = {\n path: [ [bottom, 0], [top, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bottom'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [bottom, 0], [top, 1], [1, 1], [1, 0] ]);\n\n break;\n\n case 3: /* 0011 */\n left = settings.interpolate(x0, x3, threshold);\n right = settings.interpolate(x1, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.right = {\n path: [ [1, right], [0, left] ],\n move: {\n x: -1,\n y: 0,\n enter: 'right'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, left], [0, 1], [1, 1], [1, right] ]);\n\n break;\n\n case 6: /* 0110 */\n bottom = settings.interpolate(x0, x1, threshold);\n top = settings.interpolate(x3, x2, threshold);\n\n if (settings.polygons_full) {\n cell.edges.top = {\n path: [ [top, 1], [bottom, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'top'\n }\n };\n }\n\n if (settings.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [top, 1], [bottom, 0] ]);\n\n break;\n\n case 10: /* 1010 */\n left = settings.interpolate(x0, x3, threshold);\n right = settings.interpolate(x1, x2, threshold);\n bottom = settings.interpolate(x0, x1, threshold);\n top = settings.interpolate(x3, x2, threshold);\n average = (x0 + x1 + x2 + x3) / 4;\n\n if (settings.polygons_full) {\n if (average < threshold) {\n cell.edges.left = {\n path: [ [0, left], [top, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bottom'\n }\n };\n cell.edges.right = {\n path: [ [1, right], [bottom, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'top'\n }\n };\n } else {\n cell.edges.right = {\n path: [ [1, right], [top, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bottom'\n }\n };\n cell.edges.left = {\n path: [ [0, left], [bottom, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'top'\n }\n };\n }\n }\n\n if (settings.polygons) {\n if (average < threshold) {\n cell.polygons.push([ [0, 0], [0, left], [top, 1], [1, 1], [1, right], [bottom, 0] ]);\n } else {\n cell.polygons.push([ [0, 0], [0, left], [bottom, 0] ]);\n cell.polygons.push([ [top, 1], [1, 1], [1, right] ]);\n }\n }\n\n break;\n\n case 5: /* 0101 */\n left = settings.interpolate(x0, x3, threshold);\n right = settings.interpolate(x1, x2, threshold);\n bottom = settings.interpolate(x0, x1, threshold);\n top = settings.interpolate(x3, x2, threshold);\n average = (x0 + x1 + x2 + x3) / 4;\n\n if (settings.polygons_full) {\n if (average < threshold) {\n cell.edges.bottom = {\n path: [ [bottom, 0], [0, left] ],\n move: {\n x: -1,\n y: 0,\n enter: 'right'\n }\n };\n cell.edges.top = {\n path: [ [top, 1], [1, right] ],\n move: {\n x: 1,\n y: 0,\n enter: 'left'\n }\n };\n } else {\n cell.edges.top = {\n path: [ [top, 1], [0, left] ],\n move: {\n x: -1,\n y: 0,\n enter: 'right'\n }\n };\n cell.edges.bottom = {\n path: [ [bottom, 0], [1, right] ],\n move: {\n x: 1,\n y: 0,\n enter: 'left'\n }\n };\n }\n }\n\n if (settings.polygons) {\n if (average < threshold) {\n cell.polygons.push([ [0, left], [0, 1], [top, 1], [1, right], [1, 0], [bottom, 0] ]);\n } else {\n cell.polygons.push([ [0, left], [0, 1], [top, 1] ]);\n cell.polygons.push([ [bottom, 0], [1, right], [1, 0] ]);\n }\n }\n\n break;\n }\n\n return cell;\n}\n\n/* eslint no-console: [\"error\", { allow: [\"log\"] }] */\n\n\n/*\n * lookup table to generate polygon paths or edges required to\n * trace the full polygon(s)\n */\nvar shapeCoordinates = {\n square: function(cell, x0, x1, x2, x3, opt) {\n if (opt.polygons)\n cell.polygons.push([ [0,0], [0, 1], [1, 1], [1, 0] ]);\n },\n\n triangle_bl: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, leftbottom], [bottomleft, 0], [0, 0] ]);\n },\n\n triangle_br: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright, 0], [1, rightbottom], [1, 0] ]);\n },\n\n triangle_tr: function(cell, x0, x1, x2, x3, opt) {\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.rt = {\n path: [ [1, righttop], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [1, righttop], [topright, 1], [1, 1] ]);\n },\n\n triangle_tl: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tl = {\n path: [ [topleft, 1], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, lefttop], [0, 1], [topleft, 1] ]);\n },\n\n tetragon_t: function(cell, x0, x1, x2, x3, opt) {\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.rt = {\n path: [ [1, righttop], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, lefttop], [0, 1], [1, 1], [1, righttop] ]);\n },\n\n tetragon_r: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright, 0], [topright, 1], [1, 1], [1, 0] ]);\n },\n\n tetragon_b: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [1, rightbottom], [1, 0] ]);\n },\n\n tetragon_l: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tl = {\n path: [ [topleft, 1], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [topleft, 1], [bottomleft, 0] ]);\n },\n\n tetragon_bl: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [0, leftbottom], [0, lefttop], [bottomright, 0] ]);\n },\n\n tetragon_br: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [1, righttop], [1, rightbottom], [bottomright, 0] ]);\n },\n\n tetragon_tr: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.rb = {\n path: [ [1, rightbottom], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [1, rightbottom], [topleft, 1], [topright, 1], [1, righttop] ]);\n },\n\n tetragon_tl: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tr = {\n path: [ [topright, 1], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [topright, 1], [0, leftbottom], [0, lefttop], [topleft, 1] ]);\n },\n\n tetragon_lr: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lt = {\n path: [ [0, lefttop], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, leftbottom], [0, lefttop], [1, righttop], [1, rightbottom] ]);\n },\n\n tetragon_tb: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tr = {\n path: [ [topright, 1], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n cell.edges.bl = {\n path: [ [bottomleft, 0], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [topleft, 1], [topright, 1], [bottomright, 0] ]);\n },\n\n pentagon_tr: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tl = {\n path: [[topleft, 1], [1, rightbottom]],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [topleft, 1], [1, rightbottom], [1, 0] ]);\n },\n\n pentagon_tl: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [topright, 1], [1, 1], [1, 0] ]);\n },\n\n pentagon_br: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.rt = {\n path: [ [1, righttop], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [1, 1], [1, righttop], [bottomleft, 0] ]);\n },\n\n pentagon_bl: function(cell, x0, x1, x2, x3, opt) {\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, lefttop], [0, 1], [1, 1], [1, 0], [bottomright, 0] ]);\n },\n\n pentagon_tr_rl: function(cell, x0, x1, x2, x3, opt) {\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tl = {\n path: [ [topleft, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, lefttop], [0, 1], [topleft, 1], [1, righttop], [1, rightbottom] ]);\n },\n\n pentagon_rb_bt: function(cell, x0, x1, x2, x3, opt) {\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.rt = {\n path: [ [1, righttop], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n cell.edges.bl = {\n path: [ [bottomleft, 0], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [topright, 1], [1, 1], [1, righttop], [bottomright, 0], [bottomleft, 0] ]);\n },\n\n pentagon_bl_lr: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright, 0], [0, leftbottom], [0, lefttop], [1, rightbottom], [1, 0] ]);\n },\n\n pentagon_lt_tb: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [topleft, 1], [topright, 1], [bottomleft, 0] ]);\n },\n\n pentagon_bl_tb: function(cell, x0, x1, x2, x3, opt) {\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n cell.edges.tl = {\n path: [ [ topleft, 1], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, lefttop], [0, 1], [topleft, 1], [bottomright, 0], [bottomleft, 0] ]);\n },\n\n pentagon_lt_rl: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate(x1, x3, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lt = {\n path: [ [0, lefttop], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n cell.edges.rt = {\n path: [ [1, righttop], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, leftbottom], [0, lefttop], [topright, 1], [1, 1], [1, righttop] ]);\n },\n\n pentagon_tr_bt: function(cell, x0, x1, x2, x3, opt) {\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [topleft, 1], [topright, 1], [1, rightbottom], [1, 0], [bottomright, 0] ]);\n },\n\n pentagon_rb_lr: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [1, righttop], [1, rightbottom], [bottomleft, 0] ]);\n },\n\n hexagon_lt_tr: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [topleft, 1], [topright, 1], [1, rightbottom], [1, 0] ]);\n },\n\n hexagon_bl_lt: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright, 0], [0, leftbottom], [0, lefttop], [topright, 1], [1, 1], [1, 0] ]);\n },\n\n hexagon_bl_rb: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n cell.edges.rt = {\n path: [ [1, righttop], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [0, lefttop], [0, 1], [1, 1], [1, righttop], [bottomright, 0] ]);\n },\n\n hexagon_tr_rb: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.tl = {\n path: [ [topleft, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, 1], [topleft, 1], [1, righttop], [1, rightbottom], [bottomleft, 0] ]);\n },\n\n hexagon_lt_rb: function(cell, x0, x1, x2, x3, opt) {\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n cell.edges.rt = {\n path: [ [1, righttop], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [topright, 1], [1, 1], [1, righttop], [bottomleft, 0] ]);\n },\n\n hexagon_bl_tr: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n cell.edges.tl = {\n path: [ [topleft, 1], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright, 0], [0, lefttop], [0, 1], [topleft, 1], [1, rightbottom], [1, 0] ]);\n },\n\n heptagon_tr: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var topright = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [topright, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'br'\n }\n };\n cell.edges.rt = {\n path: [ [1, righttop], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [0, leftbottom], [0, lefttop], [topright, 1], [1, 1], [1, righttop], [bottomright, 0] ]);\n },\n\n heptagon_bl: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.lb = {\n path: [ [0, leftbottom], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomleft, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tl'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [0, 0], [0, leftbottom], [topleft, 1], [topright, 1], [1, righttop], [1, rightbottom], [bottomleft, 0] ]);\n },\n\n heptagon_tl: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var lefttop = opt.interpolate(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, lefttop] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rt'\n }\n };\n cell.edges.tl = {\n path: [ [topleft, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [0, lefttop], [0, 1], [topleft, 1], [1, righttop], [1, rightbottom], [bottomright, 0] ]);\n },\n\n heptagon_br: function(cell, x0, x1, x2, x3, opt) {\n var bottomright = opt.interpolate(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.br = {\n path: [ [bottomright, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, rightbottom] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lb'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomright,0], [0, leftbottom], [0, lefttop], [topleft, 1], [topright, 1], [1, rightbottom], [1, 0] ]);\n },\n\n octagon: function(cell, x0, x1, x2, x3, opt) {\n var bottomleft = opt.interpolate_a(x0, x1, opt.minV, opt.maxV);\n var bottomright = opt.interpolate_b(x0, x1, opt.minV, opt.maxV);\n var leftbottom = opt.interpolate_a(x0, x3, opt.minV, opt.maxV);\n var lefttop = opt.interpolate_b(x0, x3, opt.minV, opt.maxV);\n var topleft = opt.interpolate_a(x3, x2, opt.minV, opt.maxV);\n var topright = opt.interpolate_b(x3, x2, opt.minV, opt.maxV);\n var righttop = opt.interpolate_b(x1, x2, opt.minV, opt.maxV);\n var rightbottom = opt.interpolate_a(x1, x2, opt.minV, opt.maxV);\n\n if (opt.polygons_full) {\n cell.edges.bl = {\n path: [ [bottomleft, 0], [0, leftbottom] ],\n move: {\n x: -1,\n y: 0,\n enter: 'rb'\n }\n };\n cell.edges.lt = {\n path: [ [0, lefttop], [topleft, 1] ],\n move: {\n x: 0,\n y: 1,\n enter: 'bl'\n }\n };\n cell.edges.tr = {\n path: [ [topright, 1], [1, righttop] ],\n move: {\n x: 1,\n y: 0,\n enter: 'lt'\n }\n };\n cell.edges.rb = {\n path: [ [1, rightbottom], [bottomright, 0] ],\n move: {\n x: 0,\n y: -1,\n enter: 'tr'\n }\n };\n }\n\n if (opt.polygons)\n cell.polygons.push([ [bottomleft, 0], [0, leftbottom], [0, lefttop], [topleft, 1], [topright, 1], [1, righttop], [1, rightbottom], [bottomright, 0] ]);\n }\n};\n\n\n/*\n * Compute isobands(s) for a scalar 2D field given a certain\n * threshold and a bandwidth by applying the Marching Squares\n * Algorithm. The function returns a list of path coordinates\n * either for individual polygons within each grid cell, or the\n * outline of connected polygons.\n */\nfunction isoBands(input, minV, bandWidth, options) {\n var i,\n j,\n settings,\n useQuadTree = false,\n tree = null,\n root = null,\n data = null,\n cellGrid = null,\n multiBand = false,\n bw = [],\n bandPolygons = [],\n ret = [];\n\n /* basic input validation */\n if (!input) throw new Error('data is required');\n if (minV === undefined || minV === null) throw new Error('lowerBound is required');\n if (bandWidth === undefined || bandWidth === null) throw new Error('bandWidth is required');\n if ((!!options) && (typeof options !== 'object')) throw new Error('options must be an object');\n\n settings = isoBandOptions(options);\n\n /* check for input data */\n if (input instanceof QuadTree) {\n tree = input;\n root = input.root;\n data = input.data;\n if (!settings.noQuadTree)\n useQuadTree = true;\n } else if (Array.isArray(input) && Array.isArray(input[0])) {\n data = input;\n } else {\n throw new Error('input is neither array of arrays nor object retrieved from \\'QuadTree()\\'');\n }\n\n /* check and prepare input thresholds */\n if (Array.isArray(minV)) {\n multiBand = true;\n\n /* activate QuadTree optimization if not explicitly forbidden by user settings */\n if (!settings.noQuadTree)\n useQuadTree = true;\n\n /* check if all minV are numbers */\n for (i = 0; i < minV.length; i++)\n if (isNaN(+minV[i]))\n throw new Error('lowerBound[' + i + '] is not a number');\n\n if (Array.isArray(bandWidth)) {\n if (minV.length !== bandWidth.length)\n throw new Error('lowerBound and bandWidth have unequal lengths');\n\n /* check bandwidth values */\n for (i = 0; i < bandWidth.length; i++)\n if (isNaN(+bandWidth[i]))\n throw new Error('bandWidth[' + i + '] is not a number');\n } else {\n if (isNaN(+bandWidth))\n throw new Error('bandWidth must be a number');\n\n bw = [];\n for (i = 0; i < minV.length; i++) {\n bw.push(bandWidth);\n }\n bandWidth = bw;\n }\n } else {\n if (isNaN(+minV))\n throw new Error('lowerBound must be a number');\n\n minV = [ minV ];\n\n if (isNaN(+bandWidth))\n throw new Error('bandWidth must be a number');\n\n bandWidth = [ bandWidth ];\n }\n\n /* create QuadTree root node if not already present */\n if ((useQuadTree) && (!root)) {\n tree = new QuadTree(data);\n root = tree.root;\n data = tree.data;\n }\n\n if (settings.verbose) {\n if(settings.polygons)\n console.log('MarchingSquaresJS-isoBands: returning single polygons for each grid cell');\n else\n console.log('MarchingSquaresJS-isoBands: returning polygon paths for entire data grid');\n\n if (multiBand)\n console.log('MarchingSquaresJS-isoBands: multiple bands requested, returning array of band polygons instead of polygons for a single band');\n }\n\n /* Done with all input validation, now let's start computing stuff */\n\n /* loop over all minV values */\n minV.forEach(function(lowerBound, b) {\n bandPolygons = [];\n\n /* store bounds for current computation in settings object */\n settings.minV = lowerBound;\n settings.maxV = lowerBound + bandWidth[b];\n\n if(settings.verbose)\n console.log('MarchingSquaresJS-isoBands: computing isobands for [' + lowerBound + ':' + (lowerBound + bandWidth[b]) + ']');\n\n if (settings.polygons) {\n /* compose list of polygons for each single cell */\n if (useQuadTree) {\n /* go through list of cells retrieved from QuadTree */\n root\n .cellsInBand(settings.minV, settings.maxV, true)\n .forEach(function(c) {\n bandPolygons = bandPolygons.concat(\n cell2Polygons(\n prepareCell$1(data,\n c.x,\n c.y,\n settings),\n c.x,\n c.y,\n settings\n ));\n });\n } else {\n /* go through entire array of input data */\n for (j = 0; j < data.length - 1; ++j) {\n for (i = 0; i < data[0].length - 1; ++i)\n bandPolygons = bandPolygons.concat(\n cell2Polygons(\n prepareCell$1(data,\n i,\n j,\n settings),\n i,\n j,\n settings\n ));\n }\n }\n } else {\n /* sparse grid of input data cells */\n cellGrid = [];\n for (i = 0; i < data[0].length - 1; ++i)\n cellGrid[i] = [];\n\n /* compose list of polygons for entire input grid */\n if (useQuadTree) {\n /* collect the cells */\n root\n .cellsInBand(settings.minV, settings.maxV, false)\n .forEach(function(c) {\n cellGrid[c.x][c.y] = prepareCell$1(data,\n c.x,\n c.y,\n settings);\n });\n } else {\n /* prepare cells */\n for (i = 0; i < data[0].length - 1; ++i) {\n for (j = 0; j < data.length - 1; ++j) {\n cellGrid[i][j] = prepareCell$1(data,\n i,\n j,\n settings);\n }\n }\n }\n\n bandPolygons = traceBandPaths(data, cellGrid, settings);\n }\n\n /* finally, add polygons to output array */\n if (multiBand)\n ret.push(bandPolygons);\n else\n ret = bandPolygons;\n\n if(typeof settings.successCallback === 'function')\n settings.successCallback(ret, lowerBound, bandWidth[b]);\n });\n\n return ret;\n}\n\n/*\n * Thats all for the public interface, below follows the actual\n * implementation\n */\n\n/*\n * For isoBands, each square is defined by the three states\n * of its corner points. However, since computers use power-2\n * values, we use 2bits per trit, i.e.:\n *\n * 00 ... below minV\n * 01 ... between minV and maxV\n * 10 ... above maxV\n *\n * Hence we map the 4-trit configurations as follows:\n *\n * 0000 => 0\n * 0001 => 1\n * 0002 => 2\n * 0010 => 4\n * 0011 => 5\n * 0012 => 6\n * 0020 => 8\n * 0021 => 9\n * 0022 => 10\n * 0100 => 16\n * 0101 => 17\n * 0102 => 18\n * 0110 => 20\n * 0111 => 21\n * 0112 => 22\n * 0120 => 24\n * 0121 => 25\n * 0122 => 26\n * 0200 => 32\n * 0201 => 33\n * 0202 => 34\n * 0210 => 36\n * 0211 => 37\n * 0212 => 38\n * 0220 => 40\n * 0221 => 41\n * 0222 => 42\n * 1000 => 64\n * 1001 => 65\n * 1002 => 66\n * 1010 => 68\n * 1011 => 69\n * 1012 => 70\n * 1020 => 72\n * 1021 => 73\n * 1022 => 74\n * 1100 => 80\n * 1101 => 81\n * 1102 => 82\n * 1110 => 84\n * 1111 => 85\n * 1112 => 86\n * 1120 => 88\n * 1121 => 89\n * 1122 => 90\n * 1200 => 96\n * 1201 => 97\n * 1202 => 98\n * 1210 => 100\n * 1211 => 101\n * 1212 => 102\n * 1220 => 104\n * 1221 => 105\n * 1222 => 106\n * 2000 => 128\n * 2001 => 129\n * 2002 => 130\n * 2010 => 132\n * 2011 => 133\n * 2012 => 134\n * 2020 => 136\n * 2021 => 137\n * 2022 => 138\n * 2100 => 144\n * 2101 => 145\n * 2102 => 146\n * 2110 => 148\n * 2111 => 149\n * 2112 => 150\n * 2120 => 152\n * 2121 => 153\n * 2122 => 154\n * 2200 => 160\n * 2201 => 161\n * 2202 => 162\n * 2210 => 164\n * 2211 => 165\n * 2212 => 166\n * 2220 => 168\n * 2221 => 169\n * 2222 => 170\n */\n\n/*\n * ####################################\n * Some small helper functions\n * ####################################\n */\n\nfunction computeCenterAverage(bl, br, tr, tl, minV, maxV) {\n var average = (tl + tr + br + bl) / 4;\n\n if (average > maxV)\n return 2; /* above isoband limits */\n\n if (average < minV)\n return 0; /* below isoband limits */\n\n return 1; /* within isoband limits */\n}\n\n\nfunction prepareCell$1(grid, x, y, opt) {\n var cell,\n center_avg;\n\n /* compose the 4-trit corner representation */\n var cval = 0;\n var x3 = grid[y + 1][x];\n var x2 = grid[y + 1][x + 1];\n var x1 = grid[y][x + 1];\n var x0 = grid[y][x];\n var minV = opt.minV;\n var maxV = opt.maxV;\n\n /*\n * Note that missing data within the grid will result\n * in horribly failing to trace full polygon paths\n */\n if(isNaN(x0) || isNaN(x1) || isNaN(x2) || isNaN(x3)) {\n return;\n }\n\n /*\n * Here we detect the type of the cell\n *\n * x3 ---- x2\n * | |\n * | |\n * x0 ---- x1\n *\n * with edge points\n *\n * x0 = (x,y),\n * x1 = (x + 1, y),\n * x2 = (x + 1, y + 1), and\n * x3 = (x, y + 1)\n *\n * and compute the polygon intersections with the edges\n * of the cell. Each edge value may be (i) below, (ii) within,\n * or (iii) above the values of the isoband limits. We\n * encode this property using 2 bits of information, where\n *\n * 00 ... below,\n * 01 ... within, and\n * 10 ... above\n *\n * Then we store the cells value as vector\n *\n * cval = (x0, x1, x2, x3)\n *\n * where x0 are the two least significant bits (0th, 1st),\n * x1 the 2nd and 3rd bit, and so on. This essentially\n * enables us to work with a single integer number\n */\n\n cval |= (x3 < minV) ? 0 : (x3 > maxV) ? 128 : 64;\n cval |= (x2 < minV) ? 0 : (x2 > maxV) ? 32 : 16;\n cval |= (x1 < minV) ? 0 : (x1 > maxV) ? 8 : 4;\n cval |= (x0 < minV) ? 0 : (x0 > maxV) ? 2 : 1;\n\n /* make sure cval is a number */\n cval = +cval;\n\n /*\n * cell center average trit for ambiguous cases, where\n * 0 ... below iso band\n * 1 ... within iso band\n * 2 ... above isoband\n */\n center_avg = 0;\n\n cell = {\n cval: cval,\n polygons: [],\n edges: {},\n x0: x0,\n x1: x1,\n x2: x2,\n x3: x3,\n x: x,\n y: y\n };\n\n /*\n * Compute interpolated intersections of the polygon(s)\n * with the cell borders and (i) add edges for polygon\n * trace-back, or (ii) a list of small closed polygons\n * according to look-up table\n */\n switch (cval) {\n case 85: /* 1111 */\n shapeCoordinates.square(cell, x0, x1, x2, x3, opt);\n /* fall through */\n case 0: /* 0000 */\n /* fall through */\n case 170: /* 2222 */\n break;\n\n /* single triangle cases */\n\n case 169: /* 2221 */\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 166: /* 2212 */\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 154: /* 2122 */\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 106: /* 1222 */\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 1: /* 0001 */\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 4: /* 0010 */\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 16: /* 0100 */\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 64: /* 1000 */\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n\n /* single trapezoid cases */\n\n case 168: /* 2220 */\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 162: /* 2202 */\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 138: /* 2022 */\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 42: /* 0222 */\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 2: /* 0002 */\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 8: /* 0020 */\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 32: /* 0200 */\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 128: /* 2000 */\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n\n /* single rectangle cases */\n\n case 5: /* 0011 */\n shapeCoordinates.tetragon_b(cell, x0, x1, x2, x3, opt);\n break;\n\n case 20: /* 0110 */\n shapeCoordinates.tetragon_r(cell, x0, x1, x2, x3, opt);\n break;\n\n case 80: /* 1100 */\n shapeCoordinates.tetragon_t(cell, x0, x1, x2, x3, opt);\n break;\n\n case 65: /* 1001 */\n shapeCoordinates.tetragon_l(cell, x0, x1, x2, x3, opt);\n break;\n\n case 165: /* 2211 */\n shapeCoordinates.tetragon_b(cell, x0, x1, x2, x3, opt);\n break;\n\n case 150: /* 2112 */\n shapeCoordinates.tetragon_r(cell, x0, x1, x2, x3, opt);\n break;\n\n case 90: /* 1122 */\n shapeCoordinates.tetragon_t(cell, x0, x1, x2, x3, opt);\n break;\n\n case 105: /* 1221 */\n shapeCoordinates.tetragon_l(cell, x0, x1, x2, x3, opt);\n break;\n\n case 160: /* 2200 */\n shapeCoordinates.tetragon_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 130: /* 2002 */\n shapeCoordinates.tetragon_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 10: /* 0022 */\n shapeCoordinates.tetragon_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 40: /* 0220 */\n shapeCoordinates.tetragon_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n\n /* single pentagon cases */\n\n case 101: /* 1211 */\n shapeCoordinates.pentagon_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 149: /* 2111 */\n shapeCoordinates.pentagon_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 86: /* 1112 */\n shapeCoordinates.pentagon_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 89: /* 1121 */\n shapeCoordinates.pentagon_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 69: /* 1011 */\n shapeCoordinates.pentagon_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 21: /* 0111 */\n shapeCoordinates.pentagon_tl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 84: /* 1110 */\n shapeCoordinates.pentagon_bl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 81: /* 1101 */\n shapeCoordinates.pentagon_br(cell, x0, x1, x2, x3, opt);\n break;\n\n case 96: /* 1200 */\n shapeCoordinates.pentagon_tr_rl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 24: /* 0120 */\n shapeCoordinates.pentagon_rb_bt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 6: /* 0012 */\n shapeCoordinates.pentagon_bl_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 129: /* 2001 */\n shapeCoordinates.pentagon_lt_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 74: /* 1022 */\n shapeCoordinates.pentagon_tr_rl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 146: /* 2102 */\n shapeCoordinates.pentagon_rb_bt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 164: /* 2210 */\n shapeCoordinates.pentagon_bl_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 41: /* 0221 */\n shapeCoordinates.pentagon_lt_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 66: /* 1002 */\n shapeCoordinates.pentagon_bl_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 144: /* 2100 */\n shapeCoordinates.pentagon_lt_rl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 36: /* 0210 */\n shapeCoordinates.pentagon_tr_bt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 9: /* 0021 */\n shapeCoordinates.pentagon_rb_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 104: /* 1220 */\n shapeCoordinates.pentagon_bl_tb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 26: /* 0122 */\n shapeCoordinates.pentagon_lt_rl(cell, x0, x1, x2, x3, opt);\n break;\n\n case 134: /* 2012 */\n shapeCoordinates.pentagon_tr_bt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 161: /* 2201 */\n shapeCoordinates.pentagon_rb_lr(cell, x0, x1, x2, x3, opt);\n break;\n\n\n /* single hexagon cases */\n\n case 37: /* 0211 */\n shapeCoordinates.hexagon_lt_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 148: /* 2110 */\n shapeCoordinates.hexagon_bl_lt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 82: /* 1102 */\n shapeCoordinates.hexagon_bl_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 73: /* 1021 */\n shapeCoordinates.hexagon_tr_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 133: /* 2011 */\n shapeCoordinates.hexagon_lt_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 22: /* 0112 */\n shapeCoordinates.hexagon_bl_lt(cell, x0, x1, x2, x3, opt);\n break;\n\n case 88: /* 1120 */\n shapeCoordinates.hexagon_bl_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 97: /* 1201 */\n shapeCoordinates.hexagon_tr_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 145: /* 2101 */\n shapeCoordinates.hexagon_lt_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 25: /* 0121 */\n shapeCoordinates.hexagon_lt_rb(cell, x0, x1, x2, x3, opt);\n break;\n\n case 70: /* 1012 */\n shapeCoordinates.hexagon_bl_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n case 100: /* 1210 */\n shapeCoordinates.hexagon_bl_tr(cell, x0, x1, x2, x3, opt);\n break;\n\n\n /* 6-sided saddles */\n\n case 17: /* 0101 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.hexagon_lt_rb(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 68: /* 1010 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.hexagon_bl_tr(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 153: /* 2121 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.hexagon_lt_rb(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 102: /* 1212 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.hexagon_bl_tr(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n\n /* 7-sided saddles */\n\n case 152: /* 2120 */\n\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_tr(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 137: /* 2021 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_bl(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 98: /* 1202 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_tl(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 38: /* 0212 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 0 */\n if (center_avg === 2) {\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_br(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 18: /* 0102 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_tr(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_tr(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 33: /* 0201 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_bl(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 72: /* 1020 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_tl(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 132: /* 2010 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n /* should never be center_avg === 2 */\n if (center_avg === 0) {\n shapeCoordinates.triangle_br(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.heptagon_br(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n\n /* 8-sided saddles */\n\n case 136: /* 2020 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n if (center_avg === 0) {\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n } else if (center_avg === 1) {\n shapeCoordinates.octagon(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n }\n break;\n\n case 34: /* 0202 */\n center_avg = computeCenterAverage(x0, x1, x2, x3, minV, maxV);\n if (center_avg === 0) {\n shapeCoordinates.tetragon_bl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_tr(cell, x0, x1, x2, x3, opt);\n } else if (center_avg === 1) {\n shapeCoordinates.octagon(cell, x0, x1, x2, x3, opt);\n } else {\n shapeCoordinates.tetragon_tl(cell, x0, x1, x2, x3, opt);\n shapeCoordinates.tetragon_br(cell, x0, x1, x2, x3, opt);\n }\n break;\n }\n\n return cell;\n}\n\nexport { isoLines, isoLines as isoContours, isoBands, QuadTree, QuadTree as quadTree };\n","var coordEach = require('@turf/meta').coordEach;\n\n/**\n * Takes a set of features, calculates the bbox of all input features, and returns a bounding box.\n *\n * @name bbox\n * @param {FeatureCollection|Feature} geojson input features\n * @returns {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @example\n * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]]);\n * var bbox = turf.bbox(line);\n * var bboxPolygon = turf.bboxPolygon(bbox);\n *\n * //addToMap\n * var addToMap = [line, bboxPolygon]\n */\nmodule.exports = function (geojson) {\n var bbox = [Infinity, Infinity, -Infinity, -Infinity];\n coordEach(geojson, function (coord) {\n if (bbox[0] > coord[0]) bbox[0] = coord[0];\n if (bbox[1] > coord[1]) bbox[1] = coord[1];\n if (bbox[2] < coord[0]) bbox[2] = coord[0];\n if (bbox[3] < coord[1]) bbox[3] = coord[1];\n });\n return bbox;\n};\n","var jsts = require('jsts');\n\n/**\n * Takes two or more {@link Polygon|polygons} and returns a combined polygon. If the input polygons are not contiguous, this function returns a {@link MultiPolygon} feature.\n *\n * @name union\n * @param {...Feature} A polygon to combine\n * @returns {Feature<(Polygon|MultiPolygon)>} a combined {@link Polygon} or {@link MultiPolygon} feature\n * @example\n * var poly1 = turf.polygon([[\n * [-82.574787, 35.594087],\n * [-82.574787, 35.615581],\n * [-82.545261, 35.615581],\n * [-82.545261, 35.594087],\n * [-82.574787, 35.594087]\n * ]], {\"fill\": \"#0f0\"});\n * var poly2 = turf.polygon([[\n * [-82.560024, 35.585153],\n * [-82.560024, 35.602602],\n * [-82.52964, 35.602602],\n * [-82.52964, 35.585153],\n * [-82.560024, 35.585153]\n * ]], {\"fill\": \"#00f\"});\n *\n * var union = turf.union(poly1, poly2);\n *\n * //addToMap\n * var addToMap = [poly1, poly2, union];\n */\nmodule.exports = function () {\n var reader = new jsts.io.GeoJSONReader();\n var result = reader.read(JSON.stringify(arguments[0].geometry));\n\n for (var i = 1; i < arguments.length; i++) {\n result = result.union(reader.read(JSON.stringify(arguments[i].geometry)));\n }\n\n var writer = new jsts.io.GeoJSONWriter();\n result = writer.write(result);\n\n return {\n type: 'Feature',\n geometry: result,\n properties: arguments[0].properties\n };\n};\n","// https://en.wikipedia.org/wiki/Rhumb_line\n// http://www.movable-type.co.uk/scripts/latlong.html#rhumblines\nvar helpers = require('@turf/helpers');\nvar getCoord = require('@turf/invariant').getCoord;\nvar GeodesyLatLon = require('geodesy').LatLonSpherical;\nvar radiansToDistance = helpers.radiansToDistance;\nvar distanceToRadians = helpers.distanceToRadians;\n\n/**\n * Calculates the distance along a rhumb line between two {@link Point|points} in degrees, radians,\n * miles, or kilometers.\n *\n * @name rhumbDistance\n * @param {Geometry|Feature|Array} from origin point\n * @param {Geometry|Feature|Array} to destination point\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {number} distance between the two points\n * @example\n * var from = turf.point([-75.343, 39.984]);\n * var to = turf.point([-75.534, 39.123]);\n *\n * var distance = turf.rhumbDistance(from, to, \"miles\");\n *\n * //addToMap\n * var addToMap = [from, to];\n * from.properties.distance = distance;\n * to.properties.distance = distance;\n */\nmodule.exports = function (from, to, units) {\n // validation\n if (!from) throw new Error('from point is required');\n if (!to) throw new Error('to point is required');\n\n units = units || 'kilometers';\n\n var coordsFrom = getCoord(from);\n var coordsTo = getCoord(to);\n var origin = new GeodesyLatLon(coordsFrom[1], coordsFrom[0]);\n var destination = new GeodesyLatLon(coordsTo[1], coordsTo[0]);\n\n // compensate the crossing of the 180th meridian (https://macwright.org/2016/09/26/the-180th-meridian.html)\n // solution from https://github.com/mapbox/mapbox-gl-js/issues/3250#issuecomment-294887678\n destination[0] += (destination[0] - origin[0] > 180) ? -360 : (origin[0] - destination[0] > 180) ? 360 : 0;\n var distanceInMeters = origin.rhumbDistanceTo(destination);\n var distance = radiansToDistance(distanceToRadians(distanceInMeters, 'meters'), units);\n return distance;\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"red-border\"},[_c('div',{staticClass:\"red-border-inputs\"},[_c('div',{staticClass:\"red-border-checkbox\"},[_c('BsCheckbox',{scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"Common.SR_Common.checkbox.label.useRedBorder\")])]},proxy:true},{key:\"description\",fn:function(){return [_c('IxRes',[_vm._v(\"Common.SR_Common.infos.useRedBorder\")])]},proxy:true}]),model:{value:(_vm.enabledModel),callback:function ($$v) {_vm.enabledModel=$$v},expression:\"enabledModel\"}})],1),_c('NumericInput',{attrs:{\"disabled\":!_vm.enabled,\"rule\":function (x) { return x > 0; },\"integer\":\"\",\"unit\":\"m\",\"name\":\"buffer\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"Common.SR_Common.inputs.label.redBorderBuffer\")])]},proxy:true}]),model:{value:(_vm.valueModel),callback:function ($$v) {_vm.valueModel=$$v},expression:\"valueModel\"}})],1),(_vm.bufferedFeature === undefined)?_c('HelpBox',{attrs:{\"type\":\"danger\"}},[_c('IxRes',[_vm._v(\"Common.SR_Common.hints.wrongBufferSize\")])],1):_vm._e(),_c('IxVectorLayer',{attrs:{\"features\":_vm.previewFeatures,\"vector-style\":_vm.style,\"z-index\":3}})],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./RedBorderPreview.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!./RedBorderPreview.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./RedBorderPreview.vue?vue&type=template&id=39b7d188&lang=html&\"\nimport script from \"./RedBorderPreview.vue?vue&type=script&lang=js&\"\nexport * from \"./RedBorderPreview.vue?vue&type=script&lang=js&\"\nimport style0 from \"./RedBorderPreview.vue?vue&type=style&index=0&lang=scss&\"\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","'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('./util'),\n orientationIndex = _require.orientationIndex,\n envelopeIsEqual = _require.envelopeIsEqual,\n envelopeContains = _require.envelopeContains,\n coordinatesEqual = _require.coordinatesEqual,\n _require2 = require('@turf/helpers'),\n multiPoint = _require2.multiPoint,\n polygon = _require2.polygon,\n point = _require2.point,\n envelope = require('@turf/envelope'),\n _inside = require('@turf/inside');\n\n/** Ring of edges which form a polygon.\n * The ring may be either an outer shell or a hole.\n *\n * This class is inspired in GEOS's geos::operation::polygonize::EdgeRing\n */\n\n\nvar EdgeRing = function () {\n function EdgeRing() {\n _classCallCheck(this, EdgeRing);\n\n this.edges = [];\n this.polygon = undefined; //< Caches Polygon representation\n this.envelope = undefined; //< Caches Envelope representation\n }\n\n /** Add an edge to the ring, inserting it in the last position.\n *\n * @param {Edge} edge - Edge to be inserted\n */\n\n\n _createClass(EdgeRing, [{\n key: 'push',\n value: function push(edge) {\n // Emulate Array getter ([]) behaviour\n this[this.edges.length] = edge;\n this.edges.push(edge);\n this.polygon = this.envelope = undefined;\n }\n\n /** Get Edge.\n *\n * @param {Number} i - Index\n * @returns {Edge} - Edge in the i position\n */\n\n }, {\n key: 'get',\n value: function get(i) {\n return this.edges[i];\n }\n\n /** Getter of length property.\n *\n * @returns {Number} - Length of the edge ring.\n */\n\n }, {\n key: 'forEach',\n\n\n /** Similar to Array.prototype.forEach for the list of Edges in the EdgeRing.\n *\n * @param {Function} f - The same function to be passed to Array.prototype.forEach\n */\n value: function forEach(f) {\n this.edges.forEach(f);\n }\n\n /** Similar to Array.prototype.map for the list of Edges in the EdgeRing.\n *\n * @param {Function} f - The same function to be passed to Array.prototype.map\n * @returns {Array} - The mapped values in the function\n */\n\n }, {\n key: 'map',\n value: function map(f) {\n return this.edges.map(f);\n }\n\n /** Similar to Array.prototype.some for the list of Edges in the EdgeRing.\n *\n * @param {Function} f - The same function to be passed to Array.prototype.some\n * @returns {Boolean} - True if an Edge check the condition\n */\n\n }, {\n key: 'some',\n value: function some(f) {\n return this.edges.some(f);\n }\n\n /** Check if the ring is valid in geomtry terms.\n * A ring must have either 0 or 4 or more points. The first and the last must be\n * equal (in 2D)\n * geos::geom::LinearRing::validateConstruction\n *\n * @returns {Boolean} - Validity of the EdgeRing\n */\n\n }, {\n key: 'isValid',\n value: function isValid() {\n // TODO: stub\n return true;\n }\n\n /** Tests whether this ring is a hole.\n * A ring is a hole if it is oriented counter-clockwise.\n * Similar implementation of geos::algorithm::CGAlgorithms::isCCW\n * @returns {Boolean} - true: if it is a hole\n */\n\n }, {\n key: 'isHole',\n value: function isHole() {\n var _this = this;\n\n // XXX: Assuming Ring is valid\n // Find highest point\n var hiIndex = this.edges.reduce(function (high, edge, i) {\n if (edge.from.coordinates[1] > _this.edges[high].from.coordinates[1]) high = i;\n return high;\n }, 0),\n iPrev = (hiIndex === 0 ? this.length : hiIndex) - 1,\n iNext = (hiIndex + 1) % this.length,\n disc = orientationIndex(this.edges[iPrev].from.coordinates, this.edges[hiIndex].from.coordinates, this.edges[iNext].from.coordinates);\n\n if (disc === 0) return this.edges[iPrev].from.coordinates[0] > this.edges[iNext].from.coordinates[0];\n return disc > 0;\n }\n\n /** Creates a MultiPoint representing the EdgeRing (discarts edges directions).\n * @returns {Feature} - Multipoint representation of the EdgeRing\n */\n\n }, {\n key: 'toMultiPoint',\n value: function toMultiPoint() {\n return multiPoint(this.edges.map(function (edge) {\n return edge.from.coordinates;\n }));\n }\n\n /** Creates a Polygon representing the EdgeRing.\n * @returns {Feature} - Polygon representation of the Edge Ring\n */\n\n }, {\n key: 'toPolygon',\n value: function toPolygon() {\n if (this.polygon) return this.polygon;\n var coordinates = this.edges.map(function (edge) {\n return edge.from.coordinates;\n });\n coordinates.push(this.edges[0].from.coordinates);\n return this.polygon = polygon([coordinates]);\n }\n\n /** Calculates the envelope of the EdgeRing.\n * @returns {Feature} - envelope\n */\n\n }, {\n key: 'getEnvelope',\n value: function getEnvelope() {\n if (this.envelope) return this.envelope;\n return this.envelope = envelope(this.toPolygon());\n }\n\n /**\n * `geos::operation::polygonize::EdgeRing::findEdgeRingContaining`\n *\n * @param {EdgeRing} testEdgeRing - EdgeRing to look in the list\n * @param {EdgeRing[]} shellList - List of EdgeRing in which to search\n *\n * @returns {EdgeRing} - EdgeRing which contains the testEdgeRing\n */\n\n }, {\n key: 'inside',\n\n\n /** Checks if the point is inside the edgeRing\n *\n * @param {Feature} point - Point to check if it is inside the edgeRing\n * @returns {Boolean} - True if it is inside, False otherwise\n */\n value: function inside(point) {\n return _inside(point, this.toPolygon());\n }\n }, {\n key: 'length',\n get: function get() {\n return this.edges.length;\n }\n }], [{\n key: 'findEdgeRingContaining',\n value: function findEdgeRingContaining(testEdgeRing, shellList) {\n var testEnvelope = testEdgeRing.getEnvelope();\n\n var minEnvelope = void 0,\n minShell = void 0;\n shellList.forEach(function (shell) {\n var tryEnvelope = shell.getEnvelope();\n\n if (minShell) minEnvelope = minShell.getEnvelope();\n\n // the hole envelope cannot equal the shell envelope\n if (envelopeIsEqual(tryEnvelope, testEnvelope)) return;\n\n if (envelopeContains(tryEnvelope, testEnvelope)) {\n var testPoint = testEdgeRing.map(function (edge) {\n return edge.from.coordinates;\n }).find(function (pt) {\n return !shell.some(function (edge) {\n return coordinatesEqual(pt, edge.from.coordinates);\n });\n });\n\n if (testPoint && shell.inside(point(testPoint))) {\n if (!minShell || envelopeContains(minEnvelope, tryEnvelope)) minShell = shell;\n }\n }\n });\n\n return minShell;\n }\n }]);\n\n return EdgeRing;\n}();\n\nmodule.exports = EdgeRing;","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BsCheckbox.vue?vue&type=style&index=0&id=ca14c080&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BsCheckbox.vue?vue&type=style&index=0&id=ca14c080&lang=scss&scoped=true&\"","var bbox = require('@turf/bbox');\nvar point = require('@turf/helpers').point;\n\n/**\n * Takes a {@link Feature} or {@link FeatureCollection} and returns the absolute center point of all features.\n *\n * @name center\n * @param {GeoJSON} geojson GeoJSON to be centered\n * @param {Object} [properties] an Object that is used as the {@link Feature}'s properties\n * @returns {Feature} a Point feature at the absolute center point of all input features\n * @example\n * var features = turf.featureCollection([\n * turf.point( [-97.522259, 35.4691]),\n * turf.point( [-97.502754, 35.463455]),\n * turf.point( [-97.508269, 35.463245])\n * ]);\n *\n * var center = turf.center(features);\n *\n * //addToMap\n * var addToMap = [features, center]\n * center.properties['marker-size'] = 'large';\n * center.properties['marker-color'] = '#000';\n */\nmodule.exports = function (geojson, properties) {\n var ext = bbox(geojson);\n var x = (ext[0] + ext[2]) / 2;\n var y = (ext[1] + ext[3]) / 2;\n return point([x, y], properties);\n};\n","var tin = require('@turf/tin');\nvar helpers = require('@turf/helpers');\nvar distance = require('@turf/distance');\nvar dissolve = require('geojson-dissolve');\nvar featureEach = require('@turf/meta').featureEach;\nvar feature = helpers.feature;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a set of {@link Point|points} and returns a concave hull Polygon or MultiPolygon.\n * Internally, this uses [turf-tin](https://github.com/Turfjs/turf-tin) to generate geometries.\n *\n * @name concave\n * @param {FeatureCollection} points input points\n * @param {number} maxEdge the length (in 'units') of an edge necessary for part of the hull to become concave\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {Feature<(Polygon|MultiPolygon)>} a concave hull\n * @throws {Error} if maxEdge parameter is missing or unable to compute hull\n * @example\n * var points = turf.featureCollection([\n * turf.point([-63.601226, 44.642643]),\n * turf.point([-63.591442, 44.651436]),\n * turf.point([-63.580799, 44.648749]),\n * turf.point([-63.573589, 44.641788]),\n * turf.point([-63.587665, 44.64533]),\n * turf.point([-63.595218, 44.64765])\n * ]);\n *\n * var hull = turf.concave(points, 1, 'miles');\n *\n * //addToMap\n * var addToMap = [points, hull]\n */\nmodule.exports = function (points, maxEdge, units) {\n // validation\n if (!points) throw new Error('points is required');\n if (maxEdge === undefined || maxEdge === null) throw new Error('maxEdge is required');\n if (typeof maxEdge !== 'number') throw new Error('invalid maxEdge');\n\n var cleaned = removeDuplicates(points);\n\n var tinPolys = tin(cleaned);\n // calculate length of all edges and area of all triangles\n // and remove triangles that fail the max length test\n tinPolys.features = tinPolys.features.filter(function (triangle) {\n var pt1 = triangle.geometry.coordinates[0][0];\n var pt2 = triangle.geometry.coordinates[0][1];\n var pt3 = triangle.geometry.coordinates[0][2];\n var dist1 = distance(pt1, pt2, units);\n var dist2 = distance(pt2, pt3, units);\n var dist3 = distance(pt1, pt3, units);\n return (dist1 <= maxEdge && dist2 <= maxEdge && dist3 <= maxEdge);\n });\n\n if (tinPolys.features.length < 1) throw new Error('too few polygons found to compute concave hull');\n\n // merge the adjacent triangles\n var dissolved = dissolve(tinPolys.features);\n // geojson-dissolve always returns a MultiPolygon\n if (dissolved.coordinates.length === 1) {\n dissolved.coordinates = dissolved.coordinates[0];\n dissolved.type = 'Polygon';\n }\n return feature(dissolved);\n};\n\n/**\n * Removes duplicated points in a collection returning a new collection\n *\n * @private\n * @param {FeatureCollection} points to be cleaned\n * @returns {FeatureCollection} cleaned set of points\n */\nfunction removeDuplicates(points) {\n var cleaned = [];\n var existing = {};\n\n featureEach(points, function (pt) {\n if (!pt.geometry) return;\n var key = pt.geometry.coordinates.join('-');\n if (!existing.hasOwnProperty(key)) {\n cleaned.push(pt);\n existing[key] = true;\n }\n });\n return featureCollection(cleaned);\n}\n","var bbox = require('@turf/bbox');\nvar distance = require('@turf/distance');\nvar centroid = require('@turf/centroid');\nvar squareGrid = require('@turf/square-grid');\n\n/**\n *\n * Takes a FeatureCollection of points with known value, a power parameter, a cell depth, a unit of measurement\n * and returns a FeatureCollection of polygons in a square-grid with an interpolated value property \"IDW\" for each grid cell.\n * It finds application when in need of creating a continuous surface (i.e. rainfall, temperature, chemical dispersion surface...)\n * from a set of spatially scattered points.\n *\n * @name idw\n * @param {FeatureCollection} controlPoints Sampled points with known value\n * @param {string} valueField GeoJSON field containing the known value to interpolate on\n * @param {number} weight Exponent regulating the distance-decay weighting\n * @param {number} cellWidth The distance across each cell\n * @param {string} [units=kilometers] used in calculating cellSize, can be degrees, radians, miles, or kilometers\n * @returns {FeatureCollection} grid A grid of polygons with a property field named as `valueField`\n */\nmodule.exports = function (controlPoints, valueField, weight, cellWidth, units) {\n // validation\n if (!valueField) throw new Error('valueField is required');\n if (weight === undefined || weight === null) throw new Error('weight is required');\n if (cellWidth === undefined || cellWidth === null) throw new Error('cellWidth is required');\n\n // check if field containing data exists.\n var filtered = controlPoints.features.filter(function (feature) {\n return feature.properties &&\n feature.properties.hasOwnProperty(valueField);\n });\n if (filtered.length === 0) throw new Error('Specified Data Field is Missing');\n\n // create a sample square grid\n // compared to a point grid helps visualizing the output (like a raster..)\n var samplingGrid = squareGrid(bbox(controlPoints), cellWidth, units);\n var N = samplingGrid.features.length;\n for (var i = 0; i < N; i++) {\n var zw = 0;\n var sw = 0;\n // calculate the distance from each control point to cell's centroid\n for (var j = 0; j < controlPoints.features.length; j++) {\n var d = distance(centroid(samplingGrid.features[i]), controlPoints.features[j], units);\n if (d === 0) {\n zw = controlPoints.features[j].properties[valueField];\n }\n var w = 1.0 / Math.pow(d, weight);\n sw += w;\n zw += w * controlPoints.features[j].properties[valueField];\n }\n // write IDW value for each grid cell\n samplingGrid.features[i].properties[valueField] = zw / sw;\n }\n return samplingGrid;\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('FrsModuleRoot',{attrs:{\"module\":_vm.module,\"module-path\":['fieldRecordSystem', 'zoneMaps'],\"translation-namespaces\":['fi', 'Common.SR_Common'],\"setup\":_vm.loadPrerequisiteData},scopedSlots:_vm._u([{key:\"left\",fn:function(){return [_c('SatelliteImageSelection')]},proxy:true}])},[_c('ZoneMapCreation')],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"zone-map-creation\"},[_c('h3',[_c('IxRes',[_vm._v(\"frs.zoneMaps.header.zoneMapCreation\")])],1),_c('HelpBox',[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.introduction\")])],1),_c('RedBorderPreview',{attrs:{\"enabled\":_vm.useRedBorder,\"original-border\":_vm.borderGeometry},on:{\"update:enabled\":function($event){_vm.useRedBorder=$event},\"error\":function($event){return _vm.$emit('error', $event)}},model:{value:(_vm.buffer),callback:function ($$v) {_vm.buffer=$$v},expression:\"buffer\"}}),_c('VueSelectize',{attrs:{\"options\":_vm.algorithmOptions,\"name\":\"algorithm\",\"required\":\"\",\"fields\":_vm.algorithmFields},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.algorithm\")])]},proxy:true}]),model:{value:(_vm.algorithm),callback:function ($$v) {_vm.algorithm=$$v},expression:\"algorithm\"}}),_c('div',{staticClass:\"algorithm-parameters\"},[_c('h4',[_c('IxRes',[_vm._v(\"frs.zoneMaps.headers.algorithmParameters\")])],1),_c('NumericInput',{attrs:{\"name\":\"minimumCorrelation\",\"required\":\"\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.minimumCorrelation\")])]},proxy:true}]),model:{value:(_vm.minimumCorrelation),callback:function ($$v) {_vm.minimumCorrelation=$$v},expression:\"minimumCorrelation\"}}),(_vm.algorithm !== 'Old')?_c('div',[_c('VueSelectize',{attrs:{\"options\":_vm.zoneCountOptions,\"name\":\"zoneCount\",\"required\":\"\",\"allow-empty\":\"\",\"placeholder\":\"Auto\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.zoneCount\")])]},proxy:true}],null,false,438987546),model:{value:(_vm.zoneCount),callback:function ($$v) {_vm.zoneCount=$$v},expression:\"zoneCount\"}})],1):_vm._e(),(_vm.algorithm === 'Old')?_c('div',[_c('NumericInput',{attrs:{\"name\":\"classLimit\",\"required\":\"\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.classLimit\")])]},proxy:true}],null,false,178426812),model:{value:(_vm.classLimit),callback:function ($$v) {_vm.classLimit=$$v},expression:\"classLimit\"}}),_c('NumericInput',{attrs:{\"name\":\"outerClassLimit\",\"required\":\"\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.outerClassLimit\")])]},proxy:true}],null,false,3723304869),model:{value:(_vm.outerClassLimit),callback:function ($$v) {_vm.outerClassLimit=$$v},expression:\"outerClassLimit\"}})],1):_vm._e()],1),(_vm.fieldStates.selectedImageIds === 'error')?_c('HelpBox',{attrs:{\"type\":\"danger\"}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.noImagesSelected\")])],1):_vm._e(),_c('TextInput',{attrs:{\"name\":\"orderId\",\"rule\":_vm.validateOrderIdRule,\"required\":\"\"},scopedSlots:_vm._u([{key:\"label\",fn:function(){return [_c('IxRes',[_vm._v(\"frs.zoneMaps.label.orderId\")])]},proxy:true}]),model:{value:(_vm.orderId),callback:function ($$v) {_vm.orderId=$$v},expression:\"orderId\"}}),(_vm.orderId === null || _vm.orderId === '')?_c('HelpBox',{attrs:{\"type\":\"warning\"}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.noOrderIdConsequencesWarning\")])],1):_vm._e(),(_vm.mapCountForOrder > 0)?_c('HelpBox',[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.orderAlreadyHasMapsWarning\")])],1):_vm._e(),(_vm.mapCountForOrder === -1)?_c('HelpBox',{attrs:{\"type\":\"danger\"}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.orderIdNotFoundWarning\")])],1):_vm._e(),_c('div',{staticClass:\"buttons\"},[_c('FrsLoadingIndicator',{attrs:{\"loading\":_vm.creating || _vm.isLoadingMapCount,\"small\":\"\"}}),_c('IxButton',{staticClass:\"quit-button\",attrs:{\"large\":\"\",\"cancel\":\"\"},on:{\"click\":_vm.quit}}),_c('IxButton',{attrs:{\"large\":\"\",\"save\":\"\"},on:{\"click\":function($event){return _vm.onCreate()}}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.buttons.create\")])],1),_c('IxButton',{attrs:{\"large\":\"\",\"save\":\"\"},on:{\"click\":function($event){return _vm.onCreate(true)}}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.buttons.createAndQuit\")])],1)],1),_c('div',{staticClass:\"cultivationTableContainer\"},[_c('FrsLoadingIndicator',{attrs:{\"requests\":['frs.zoneMaps.getAllCultivationDataForField']}}),_c('FrsCultivationOverviewTable',{attrs:{\"cultivations\":_vm.cultivations}})],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./ZoneMapCreation.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!./ZoneMapCreation.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ZoneMapCreation.vue?vue&type=template&id=1887498b&scoped=true&lang=html&\"\nimport script from \"./ZoneMapCreation.vue?vue&type=script&lang=js&\"\nexport * from \"./ZoneMapCreation.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ZoneMapCreation.vue?vue&type=style&index=0&id=1887498b&lang=scss&scoped=true&\"\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 \"1887498b\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"satellite-image-selection\"},[_c('div',{staticClass:\"settings\"},[(_vm.shownImage)?_c('ChannelSelector',{attrs:{\"image\":_vm.shownImage},model:{value:(_vm.shownChannel),callback:function ($$v) {_vm.shownChannel=$$v},expression:\"shownChannel\"}}):_vm._e(),_c('FilterSelector',{model:{value:(_vm.filter),callback:function ($$v) {_vm.filter=$$v},expression:\"filter\"}}),_c('Search',{attrs:{\"data\":_vm.sortedImages,\"keys\":_vm.searchKeys,\"threshold\":0.15},on:{\"result\":function($event){_vm.searchResult = $event}},model:{value:(_vm.searchText),callback:function ($$v) {_vm.searchText=$$v},expression:\"searchText\"}})],1),(_vm.shownImageId)?_c('SatImageLayer',{attrs:{\"image\":_vm.shownImage,\"channel\":_vm.shownChannel}}):_vm._e(),_c('FrsCurrentFieldBorderLayer'),_c('div',{staticClass:\"image-list\"},[(_vm.searchResult || _vm.filter)?_c('HelpBox',[(_vm.filter === 'cultivations')?[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.filterImagesByCultivations\")])]:(_vm.filter === 'selected')?[_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.showingOnlySelected\")])]:_vm._e(),(_vm.searchResult)?[(_vm.searchResult.length)?_c('IxRes',{attrs:{\"context\":{0: _vm.searchResult.length}}},[_vm._v(\"frs.zoneMaps.hints.searchResultCount\")]):_c('IxRes',[_vm._v(\"frs.zoneMaps.hints.noSearchResult\")])]:_vm._e(),(_vm.notVisibleCount)?_c('IxRes',{attrs:{\"context\":{0: _vm.notVisibleCount}}},[_vm._v(\"frs.zoneMaps.hints.moreSelectedButNotVisible\")]):_vm._e()],2):_vm._e(),_vm._l(((_vm.searchResult || _vm.sortedItems)),function(item){return [(item.id)?_c('SatImageCard',{key:item.id,attrs:{\"image\":item,\"selected\":_vm.selectedImageIds.includes(item.id),\"active\":_vm.shownImageId === item.id},on:{\"toggle\":function($event){return _vm.toggleImage(item.id)}},nativeOn:{\"click\":function($event){return _vm.onClick(item.id)}}}):(_vm.filter !== 'selected')?_c('LoadMoreButton',{key:((item.from) + \"-\" + (item.to)),attrs:{\"date-range\":item,\"scheduled-date-ranges\":_vm.scheduledDateRanges},on:{\"click\":function($event){return _vm.loadSatelliteImages([item])}}}):_vm._e()]})],2)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"channel-selector\"},[_c('label',[_c('IxRes',[_vm._v(\"frs.zoneMaps.labels.channelSelector\")])],1),_c('div',{staticClass:\"btn-group btn-group-justified\"},_vm._l((_vm.availableChannels),function(channel){return _c('div',{key:channel,staticClass:\"btn-group\"},[_c('ToggleButton',{attrs:{\"value\":channel,\"disabled\":_vm.image.dataSource === 'Landsat' && channel === 'clm',\"title\":_vm.toggleButtonTitle(channel),\"required\":\"\"},model:{value:(_vm.modelProxy),callback:function ($$v) {_vm.modelProxy=$$v},expression:\"modelProxy\"}},[_vm._v(\"\\n \"+_vm._s(channel.toUpperCase())+\"\\n \")])],1)}),0)])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./ChannelSelector.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!./ChannelSelector.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ChannelSelector.vue?vue&type=template&id=9191524a&scoped=true&lang=html&\"\nimport script from \"./ChannelSelector.vue?vue&type=script&lang=js&\"\nexport * from \"./ChannelSelector.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ChannelSelector.vue?vue&type=style&index=0&id=9191524a&lang=scss&scoped=true&\"\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 \"9191524a\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"filter-selector\"},[_c('label',[_c('IxRes',[_vm._v(\"frs.zoneMaps.labels.filterSelector\")])],1),_c('div',{staticClass:\"btn-group btn-group-justified\"},_vm._l((_vm.availableFilters),function(filter){return _c('div',{key:filter,staticClass:\"btn-group\"},[_c('ToggleButton',{attrs:{\"value\":filter,\"required\":\"\"},model:{value:(_vm.modelProxy),callback:function ($$v) {_vm.modelProxy=$$v},expression:\"modelProxy\"}},[_c('IxRes',[_vm._v(\"frs.zoneMaps.buttons.filter_\"+_vm._s(filter || 'none'))])],1)],1)}),0)])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./FilterSelector.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!./FilterSelector.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./FilterSelector.vue?vue&type=template&id=cd193c48&scoped=true&lang=html&\"\nimport script from \"./FilterSelector.vue?vue&type=script&lang=js&\"\nexport * from \"./FilterSelector.vue?vue&type=script&lang=js&\"\nimport style0 from \"./FilterSelector.vue?vue&type=style&index=0&id=cd193c48&lang=scss&scoped=true&\"\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 \"cd193c48\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('IxWmsLayer',{attrs:{\"url\":_vm.url,\"layers\":_vm.layer}})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./SatImageLayer.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!./SatImageLayer.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SatImageLayer.vue?vue&type=template&id=7d428daa&scoped=true&lang=html&\"\nimport script from \"./SatImageLayer.vue?vue&type=script&lang=js&\"\nexport * from \"./SatImageLayer.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 \"7d428daa\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('ListCard',{attrs:{\"selected\":_vm.active},scopedSlots:_vm._u([{key:\"title\",fn:function(){return [_c('span',[_vm._v(_vm._s(_vm.$i18n.format(_vm.image.recordingDate, 'date'))+\" \")]),_c('small',[_vm._v(_vm._s(_vm.readableDataSource))])]},proxy:true},{key:\"header\",fn:function(){return [(_vm.goodEnough)?_c('span',{staticClass:\"thumbs-up\"},[_vm._v(\"👍\")]):_vm._e(),_c('div',{staticClass:\"bars\",attrs:{\"title\":_vm.statistics}},[_c('div',{staticClass:\"ndvi\",style:({width: ((Math.max(0, _vm.image.ndviMean * 100)) + \"%\")})}),_c('div',{staticClass:\"cloud\",style:({width: ((_vm.image.cloudMean * 100) + \"%\")})})])]},proxy:true},{key:\"addon\",fn:function(){return [_c('div',{staticClass:\"checkbox-container\",on:{\"click\":function($event){$event.stopPropagation();return _vm.$emit('toggle')}}},[_c('i',{staticClass:\"fa fa-lg\",class:[_vm.icon]})])]},proxy:true}])})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./SatImageCard.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!./SatImageCard.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SatImageCard.vue?vue&type=template&id=99411b72&scoped=true&lang=html&\"\nimport script from \"./SatImageCard.vue?vue&type=script&lang=js&\"\nexport * from \"./SatImageCard.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SatImageCard.vue?vue&type=style&index=0&id=99411b72&lang=scss&scoped=true&\"\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 \"99411b72\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"load-more\"},[_c('FrsLoadingIndicator',{attrs:{\"small\":\"\",\"loading\":_vm.scheduledDateRanges.some(function (x) { return x.to === _vm.dateRange.to && x.from === _vm.dateRange.from; })}}),_c('IxButton',{on:{\"click\":function($event){return _vm.$emit('click', _vm.dateRange)}}},[_c('IxRes',{attrs:{\"context\":{from: _vm.$i18n.format(_vm.dateRange.from, 'date'), to: _vm.$i18n.format(_vm.dateRange.to, 'date')}}},[_vm._v(\"\\n frs.zoneMaps.buttons.loadMoreImages\\n \")])],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./LoadMoreButton.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!./LoadMoreButton.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./LoadMoreButton.vue?vue&type=template&id=2913f7ac&scoped=true&lang=html&\"\nimport script from \"./LoadMoreButton.vue?vue&type=script&lang=js&\"\nexport * from \"./LoadMoreButton.vue?vue&type=script&lang=js&\"\nimport style0 from \"./LoadMoreButton.vue?vue&type=style&index=0&id=2913f7ac&lang=scss&scoped=true&\"\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 \"2913f7ac\",\n null\n \n)\n\nexport default component.exports","\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!./SatelliteImageSelection.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!./SatelliteImageSelection.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SatelliteImageSelection.vue?vue&type=template&id=b55de902&scoped=true&lang=html&\"\nimport script from \"./SatelliteImageSelection.vue?vue&type=script&lang=js&\"\nexport * from \"./SatelliteImageSelection.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SatelliteImageSelection.vue?vue&type=style&index=0&id=b55de902&lang=scss&scoped=true&\"\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 \"b55de902\",\n null\n \n)\n\nexport default component.exports","\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!./ZoneMapsModuleRoot.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!./ZoneMapsModuleRoot.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ZoneMapsModuleRoot.vue?vue&type=template&id=5a0a74e6&scoped=true&lang=html&\"\nimport script from \"./ZoneMapsModuleRoot.vue?vue&type=script&lang=js&\"\nexport * from \"./ZoneMapsModuleRoot.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 \"5a0a74e6\",\n null\n \n)\n\nexport default component.exports","var coordEach = require('@turf/meta').coordEach;\n\n/**\n * Takes a GeoJSON Feature or FeatureCollection and truncates the precision of the geometry.\n *\n * @name truncate\n * @param {FeatureCollection|Feature} geojson any GeoJSON Feature, FeatureCollection, Geometry or GeometryCollection.\n * @param {number} [precision=6] coordinate decimal precision\n * @param {number} [coordinates=3] maximum number of coordinates (primarly used to remove z coordinates)\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {FeatureCollection|Feature} layer with truncated geometry\n * @example\n * var point = turf.point([\n * 70.46923055566859,\n * 58.11088890802906,\n * 1508\n * ]);\n *\n * var truncated = turf.truncate(point);\n *\n * //addToMap\n * var addToMap = [truncated];\n */\nmodule.exports = function (geojson, precision, coordinates, mutate) {\n // default params\n precision = (precision === undefined || precision === null || isNaN(precision)) ? 6 : precision;\n coordinates = (coordinates === undefined || coordinates === null || isNaN(coordinates)) ? 3 : coordinates;\n\n // validation\n if (!geojson) throw new Error(' is required');\n if (typeof precision !== 'number') throw new Error(' must be a number');\n if (typeof coordinates !== 'number') throw new Error(' must be a number');\n\n // prevent input mutation\n if (mutate === false || mutate === undefined) geojson = JSON.parse(JSON.stringify(geojson));\n\n var factor = Math.pow(10, precision);\n\n // Truncate Coordinates\n coordEach(geojson, function (coords) {\n truncate(coords, factor, coordinates);\n });\n return geojson;\n};\n\n/**\n * Truncate Coordinates - Mutates coordinates in place\n *\n * @private\n * @param {Array} coords Geometry Coordinates\n * @param {number} factor rounding factor for coordinate decimal precision\n * @param {number} coordinates maximum number of coordinates (primarly used to remove z coordinates)\n * @returns {Array} mutated coordinates\n */\nfunction truncate(coords, factor, coordinates) {\n // Remove extra coordinates (usually elevation coordinates and more)\n if (coords.length > coordinates) coords.splice(coordinates, coords.length);\n\n // Truncate coordinate decimals\n for (var i = 0; i < coords.length; i++) {\n coords[i] = Math.round(coords[i] * factor) / factor;\n }\n return coords;\n}\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ChannelSelector.vue?vue&type=style&index=0&id=9191524a&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ChannelSelector.vue?vue&type=style&index=0&id=9191524a&lang=scss&scoped=true&\"","var polygon = require('@turf/helpers').polygon;\n\n/**\n * Takes a bbox and returns an equivalent {@link Polygon|polygon}.\n *\n * @name bboxPolygon\n * @param {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @returns {Feature} a Polygon representation of the bounding box\n * @example\n * var bbox = [0, 0, 10, 10];\n *\n * var poly = turf.bboxPolygon(bbox);\n *\n * //addToMap\n * var addToMap = [poly]\n */\nmodule.exports = function (bbox) {\n var lowLeft = [bbox[0], bbox[1]];\n var topLeft = [bbox[0], bbox[3]];\n var topRight = [bbox[2], bbox[3]];\n var lowRight = [bbox[2], bbox[1]];\n\n return polygon([[\n lowLeft,\n lowRight,\n topRight,\n topLeft,\n lowLeft\n ]]);\n};\n","var bbox = require('@turf/bbox');\nvar point = require('@turf/helpers').point;\n\n/**\n * Takes a {@link Feature} or {@link FeatureCollection} and returns the absolute center point of all features.\n *\n * @name center\n * @param {GeoJSON} geojson GeoJSON to be centered\n * @param {Object} [properties] an Object that is used as the {@link Feature}'s properties\n * @returns {Feature} a Point feature at the absolute center point of all input features\n * @example\n * var features = turf.featureCollection([\n * turf.point( [-97.522259, 35.4691]),\n * turf.point( [-97.502754, 35.463455]),\n * turf.point( [-97.508269, 35.463245])\n * ]);\n *\n * var center = turf.center(features);\n *\n * //addToMap\n * var addToMap = [features, center]\n * center.properties['marker-size'] = 'large';\n * center.properties['marker-color'] = '#000';\n */\nmodule.exports = function (geojson, properties) {\n var ext = bbox(geojson);\n var x = (ext[0] + ext[2]) / 2;\n var y = (ext[1] + ext[3]) / 2;\n return point([x, y], properties);\n};\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./LoadMoreButton.vue?vue&type=style&index=0&id=2913f7ac&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./LoadMoreButton.vue?vue&type=style&index=0&id=2913f7ac&lang=scss&scoped=true&\"","var bbox = require('@turf/bbox');\nvar meta = require('@turf/meta');\nvar helpers = require('@turf/helpers');\nvar invariant = require('@turf/invariant');\nvar gridToMatrix = require('grid-to-matrix');\nvar marchingsquares = require('marchingsquares');\nvar multiLineString = helpers.multiLineString;\nvar coordEach = meta.coordEach;\nvar collectionOf = invariant.collectionOf;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a grid {@link FeatureCollection} of {@link Point} features with z-values and an array of\n * value breaks and generates [isolines](http://en.wikipedia.org/wiki/Isoline).\n *\n * @name isolines\n * @param {FeatureCollection} pointGrid input points\n * @param {Array} breaks values of `zProperty` where to draw isolines\n * @param {string} [zProperty='elevation'] the property name in `points` from which z-values will be pulled\n * @param {Object} [propertiesToAllIsolines={}] GeoJSON properties passed to ALL isolines\n * @param {Array} [propertiesPerIsoline=[]] GeoJSON properties passed, in order, to the correspondent isoline;\n * the breaks array will define the order in which the isolines are created\n * @returns {FeatureCollection} a FeatureCollection of {@link MultiLineString} features representing isolines\n * @example\n * // create a grid of points with random z-values in their properties\n * var extent = [0, 30, 20, 50];\n * var cellWidth = 100;\n * var units = 'miles';\n * var pointGrid = turf.pointGrid(extent, cellWidth, units);\n * for (var i = 0; i < pointGrid.features.length; i++) {\n * pointGrid.features[i].properties.temperature = Math.random() * 10;\n * }\n * var breaks = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];\n *\n * var isolines = turf.isolines(pointGrid, breaks, 'temperature');\n *\n * //addToMap\n * var addToMap = [isolines];\n */\nmodule.exports = function (pointGrid, breaks, zProperty, propertiesToAllIsolines, propertiesPerIsoline) {\n // Default Params\n zProperty = zProperty || 'elevation';\n propertiesToAllIsolines = propertiesToAllIsolines || {};\n propertiesPerIsoline = propertiesPerIsoline || [];\n\n // Input validation\n collectionOf(pointGrid, 'Point', 'Input must contain Points');\n if (!breaks) throw new Error('breaks is required');\n if (!Array.isArray(breaks)) throw new Error('breaks must be an Array');\n if (!isObject(propertiesToAllIsolines)) throw new Error('propertiesToAllIsolines must be an Object');\n if (!Array.isArray(propertiesPerIsoline)) throw new Error('propertiesPerIsoline must be an Array');\n if (typeof zProperty !== 'string') throw new Error('zProperty must be a string');\n\n // Isoline methods\n var matrix = gridToMatrix(pointGrid, zProperty, true);\n var isolines = createIsoLines(matrix, breaks, zProperty, propertiesToAllIsolines, propertiesPerIsoline);\n var scaledIsolines = rescaleIsolines(isolines, matrix, pointGrid);\n\n return featureCollection(scaledIsolines);\n};\n\n/**\n * Creates the isolines lines (featuresCollection of MultiLineString features) from the 2D data grid\n *\n * Marchingsquares process the grid data as a 3D representation of a function on a 2D plane, therefore it\n * assumes the points (x-y coordinates) are one 'unit' distance. The result of the isolines function needs to be\n * rescaled, with turfjs, to the original area and proportions on the map\n *\n * @private\n * @param {Array>} matrix Grid Data\n * @param {Array} breaks Breaks\n * @param {string} zProperty name of the z-values property\n * @param {Object} [propertiesToAllIsolines={}] GeoJSON properties passed to ALL isolines\n * @param {Object} [propertiesPerIsoline=[]] GeoJSON properties passed to the correspondent isoline\n * @returns {Array} isolines\n */\nfunction createIsoLines(matrix, breaks, zProperty, propertiesToAllIsolines, propertiesPerIsoline) {\n var isolines = [];\n for (var i = 1; i < breaks.length; i++) {\n var threshold = +breaks[i]; // make sure it's a number\n\n var properties = Object.assign(\n {},\n propertiesToAllIsolines,\n propertiesPerIsoline[i]\n );\n properties[zProperty] = threshold;\n var isoline = multiLineString(marchingsquares.isoContours(matrix, threshold), properties);\n\n isolines.push(isoline);\n }\n return isolines;\n}\n\n/**\n * Translates and scales isolines\n *\n * @private\n * @param {Array} isolines to be rescaled\n * @param {Array>} matrix Grid Data\n * @param {Object} points Points by Latitude\n * @returns {Array} isolines\n */\nfunction rescaleIsolines(isolines, matrix, points) {\n\n // get dimensions (on the map) of the original grid\n var gridBbox = bbox(points); // [ minX, minY, maxX, maxY ]\n var originalWidth = gridBbox[2] - gridBbox[0];\n var originalHeigth = gridBbox[3] - gridBbox[1];\n\n // get origin, which is the first point of the last row on the rectangular data on the map\n var x0 = gridBbox[0];\n var y0 = gridBbox[1];\n\n // get number of cells per side\n var matrixWidth = matrix[0].length - 1;\n var matrixHeight = matrix.length - 1;\n\n // calculate the scaling factor between matrix and rectangular grid on the map\n var scaleX = originalWidth / matrixWidth;\n var scaleY = originalHeigth / matrixHeight;\n\n var resize = function (point) {\n point[0] = point[0] * scaleX + x0;\n point[1] = point[1] * scaleY + y0;\n };\n\n // resize and shift each point/line of the isolines\n isolines.forEach(function (isoline) {\n coordEach(isoline, resize);\n });\n return isolines;\n}\n\n/**\n * Checks input type\n *\n * @private\n * @param {*} input to be checked\n * @returns {boolean} true if the input is an Object\n */\nfunction isObject(input) {\n return (!!input) && (input.constructor === Object);\n}\n","/*\n (c) 2017, Vladimir Agafonkin\n Simplify.js, a high-performance JS polyline simplification library\n mourner.github.io/simplify-js\n*/\n\n(function () { 'use strict';\n\n// to suit your point format, run search/replace for '.x' and '.y';\n// for 3D version, see 3d branch (configurability would draw significant performance overhead)\n\n// square distance between 2 points\nfunction getSqDist(p1, p2) {\n\n var dx = p1.x - p2.x,\n dy = p1.y - p2.y;\n\n return dx * dx + dy * dy;\n}\n\n// square distance from a point to a segment\nfunction getSqSegDist(p, p1, p2) {\n\n var x = p1.x,\n y = p1.y,\n dx = p2.x - x,\n dy = p2.y - y;\n\n if (dx !== 0 || dy !== 0) {\n\n var t = ((p.x - x) * dx + (p.y - y) * dy) / (dx * dx + dy * dy);\n\n if (t > 1) {\n x = p2.x;\n y = p2.y;\n\n } else if (t > 0) {\n x += dx * t;\n y += dy * t;\n }\n }\n\n dx = p.x - x;\n dy = p.y - y;\n\n return dx * dx + dy * dy;\n}\n// rest of the code doesn't care about point format\n\n// basic distance-based simplification\nfunction simplifyRadialDist(points, sqTolerance) {\n\n var prevPoint = points[0],\n newPoints = [prevPoint],\n point;\n\n for (var i = 1, len = points.length; i < len; i++) {\n point = points[i];\n\n if (getSqDist(point, prevPoint) > sqTolerance) {\n newPoints.push(point);\n prevPoint = point;\n }\n }\n\n if (prevPoint !== point) newPoints.push(point);\n\n return newPoints;\n}\n\nfunction simplifyDPStep(points, first, last, sqTolerance, simplified) {\n var maxSqDist = sqTolerance,\n index;\n\n for (var i = first + 1; i < last; i++) {\n var sqDist = getSqSegDist(points[i], points[first], points[last]);\n\n if (sqDist > maxSqDist) {\n index = i;\n maxSqDist = sqDist;\n }\n }\n\n if (maxSqDist > sqTolerance) {\n if (index - first > 1) simplifyDPStep(points, first, index, sqTolerance, simplified);\n simplified.push(points[index]);\n if (last - index > 1) simplifyDPStep(points, index, last, sqTolerance, simplified);\n }\n}\n\n// simplification using Ramer-Douglas-Peucker algorithm\nfunction simplifyDouglasPeucker(points, sqTolerance) {\n var last = points.length - 1;\n\n var simplified = [points[0]];\n simplifyDPStep(points, 0, last, sqTolerance, simplified);\n simplified.push(points[last]);\n\n return simplified;\n}\n\n// both algorithms combined for awesome performance\nfunction simplify(points, tolerance, highestQuality) {\n\n if (points.length <= 2) return points;\n\n var sqTolerance = tolerance !== undefined ? tolerance * tolerance : 1;\n\n points = highestQuality ? points : simplifyRadialDist(points, sqTolerance);\n points = simplifyDouglasPeucker(points, sqTolerance);\n\n return points;\n}\n\n// export as AMD module / Node module / browser or worker variable\nif (typeof define === 'function' && define.amd) define(function() { return simplify; });\nelse if (typeof module !== 'undefined') {\n module.exports = simplify;\n module.exports.default = simplify;\n} else if (typeof self !== 'undefined') self.simplify = simplify;\nelse window.simplify = simplify;\n\n})();\n","'use strict';\n\nmodule.exports = earcut;\nmodule.exports.default = earcut;\n\nfunction earcut(data, holeIndices, dim) {\n\n dim = dim || 2;\n\n var hasHoles = holeIndices && holeIndices.length,\n outerLen = hasHoles ? holeIndices[0] * dim : data.length,\n outerNode = linkedList(data, 0, outerLen, dim, true),\n triangles = [];\n\n if (!outerNode || outerNode.next === outerNode.prev) return triangles;\n\n var minX, minY, maxX, maxY, x, y, invSize;\n\n if (hasHoles) outerNode = eliminateHoles(data, holeIndices, outerNode, dim);\n\n // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n if (data.length > 80 * dim) {\n minX = maxX = data[0];\n minY = maxY = data[1];\n\n for (var i = dim; i < outerLen; i += dim) {\n x = data[i];\n y = data[i + 1];\n if (x < minX) minX = x;\n if (y < minY) minY = y;\n if (x > maxX) maxX = x;\n if (y > maxY) maxY = y;\n }\n\n // minX, minY and invSize are later used to transform coords into integers for z-order calculation\n invSize = Math.max(maxX - minX, maxY - minY);\n invSize = invSize !== 0 ? 1 / invSize : 0;\n }\n\n earcutLinked(outerNode, triangles, dim, minX, minY, invSize);\n\n return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(data, start, end, dim, clockwise) {\n var i, last;\n\n if (clockwise === (signedArea(data, start, end, dim) > 0)) {\n for (i = start; i < end; i += dim) last = insertNode(i, data[i], data[i + 1], last);\n } else {\n for (i = end - dim; i >= start; i -= dim) last = insertNode(i, data[i], data[i + 1], last);\n }\n\n if (last && equals(last, last.next)) {\n removeNode(last);\n last = last.next;\n }\n\n return last;\n}\n\n// eliminate colinear or duplicate points\nfunction filterPoints(start, end) {\n if (!start) return start;\n if (!end) end = start;\n\n var p = start,\n again;\n do {\n again = false;\n\n if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n removeNode(p);\n p = end = p.prev;\n if (p === p.next) break;\n again = true;\n\n } else {\n p = p.next;\n }\n } while (again || p !== end);\n\n return end;\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n if (!ear) return;\n\n // interlink polygon nodes in z-order\n if (!pass && invSize) indexCurve(ear, minX, minY, invSize);\n\n var stop = ear,\n prev, next;\n\n // iterate through ears, slicing them one by one\n while (ear.prev !== ear.next) {\n prev = ear.prev;\n next = ear.next;\n\n if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n // cut off the triangle\n triangles.push(prev.i / dim);\n triangles.push(ear.i / dim);\n triangles.push(next.i / dim);\n\n removeNode(ear);\n\n // skipping the next vertex leads to less sliver triangles\n ear = next.next;\n stop = next.next;\n\n continue;\n }\n\n ear = next;\n\n // if we looped through the whole remaining polygon and can't find any more ears\n if (ear === stop) {\n // try filtering points and slicing again\n if (!pass) {\n earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1);\n\n // if this didn't work, try curing all small self-intersections locally\n } else if (pass === 1) {\n ear = cureLocalIntersections(ear, triangles, dim);\n earcutLinked(ear, triangles, dim, minX, minY, invSize, 2);\n\n // as a last resort, try splitting the remaining polygon into two\n } else if (pass === 2) {\n splitEarcut(ear, triangles, dim, minX, minY, invSize);\n }\n\n break;\n }\n }\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\nfunction isEar(ear) {\n var a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n // now make sure we don't have other points inside the potential ear\n var p = ear.next.next;\n\n while (p !== ear.prev) {\n if (pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) &&\n area(p.prev, p, p.next) >= 0) return false;\n p = p.next;\n }\n\n return true;\n}\n\nfunction isEarHashed(ear, minX, minY, invSize) {\n var a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n // triangle bbox; min & max are calculated like this for speed\n var minTX = a.x < b.x ? (a.x < c.x ? a.x : c.x) : (b.x < c.x ? b.x : c.x),\n minTY = a.y < b.y ? (a.y < c.y ? a.y : c.y) : (b.y < c.y ? b.y : c.y),\n maxTX = a.x > b.x ? (a.x > c.x ? a.x : c.x) : (b.x > c.x ? b.x : c.x),\n maxTY = a.y > b.y ? (a.y > c.y ? a.y : c.y) : (b.y > c.y ? b.y : c.y);\n\n // z-order range for the current triangle bbox;\n var minZ = zOrder(minTX, minTY, minX, minY, invSize),\n maxZ = zOrder(maxTX, maxTY, minX, minY, invSize);\n\n var p = ear.prevZ,\n n = ear.nextZ;\n\n // look for points inside the triangle in both directions\n while (p && p.z >= minZ && n && n.z <= maxZ) {\n if (p !== ear.prev && p !== ear.next &&\n pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) &&\n area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n\n if (n !== ear.prev && n !== ear.next &&\n pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) &&\n area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n // look for remaining points in decreasing z-order\n while (p && p.z >= minZ) {\n if (p !== ear.prev && p !== ear.next &&\n pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) &&\n area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n }\n\n // look for remaining points in increasing z-order\n while (n && n.z <= maxZ) {\n if (n !== ear.prev && n !== ear.next &&\n pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) &&\n area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n return true;\n}\n\n// go through all polygon nodes and cure small local self-intersections\nfunction cureLocalIntersections(start, triangles, dim) {\n var p = start;\n do {\n var a = p.prev,\n b = p.next.next;\n\n if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n\n triangles.push(a.i / dim);\n triangles.push(p.i / dim);\n triangles.push(b.i / dim);\n\n // remove two nodes involved\n removeNode(p);\n removeNode(p.next);\n\n p = start = b;\n }\n p = p.next;\n } while (p !== start);\n\n return p;\n}\n\n// try splitting polygon into two and triangulate them independently\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n // look for a valid diagonal that divides the polygon into two\n var a = start;\n do {\n var b = a.next.next;\n while (b !== a.prev) {\n if (a.i !== b.i && isValidDiagonal(a, b)) {\n // split the polygon in two by the diagonal\n var c = splitPolygon(a, b);\n\n // filter colinear points around the cuts\n a = filterPoints(a, a.next);\n c = filterPoints(c, c.next);\n\n // run earcut on each half\n earcutLinked(a, triangles, dim, minX, minY, invSize);\n earcutLinked(c, triangles, dim, minX, minY, invSize);\n return;\n }\n b = b.next;\n }\n a = a.next;\n } while (a !== start);\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n var queue = [],\n i, len, start, end, list;\n\n for (i = 0, len = holeIndices.length; i < len; i++) {\n start = holeIndices[i] * dim;\n end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n list = linkedList(data, start, end, dim, false);\n if (list === list.next) list.steiner = true;\n queue.push(getLeftmost(list));\n }\n\n queue.sort(compareX);\n\n // process holes from left to right\n for (i = 0; i < queue.length; i++) {\n eliminateHole(queue[i], outerNode);\n outerNode = filterPoints(outerNode, outerNode.next);\n }\n\n return outerNode;\n}\n\nfunction compareX(a, b) {\n return a.x - b.x;\n}\n\n// find a bridge between vertices that connects hole with an outer ring and and link it\nfunction eliminateHole(hole, outerNode) {\n outerNode = findHoleBridge(hole, outerNode);\n if (outerNode) {\n var b = splitPolygon(outerNode, hole);\n filterPoints(b, b.next);\n }\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(hole, outerNode) {\n var p = outerNode,\n hx = hole.x,\n hy = hole.y,\n qx = -Infinity,\n m;\n\n // find a segment intersected by a ray from the hole's leftmost point to the left;\n // segment's endpoint with lesser x will be potential connection point\n do {\n if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n var x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n if (x <= hx && x > qx) {\n qx = x;\n if (x === hx) {\n if (hy === p.y) return p;\n if (hy === p.next.y) return p.next;\n }\n m = p.x < p.next.x ? p : p.next;\n }\n }\n p = p.next;\n } while (p !== outerNode);\n\n if (!m) return null;\n\n if (hx === qx) return m.prev; // hole touches outer segment; pick lower endpoint\n\n // look for points inside the triangle of hole point, segment intersection and endpoint;\n // if there are no points found, we have a valid connection;\n // otherwise choose the point of the minimum angle with the ray as connection point\n\n var stop = m,\n mx = m.x,\n my = m.y,\n tanMin = Infinity,\n tan;\n\n p = m.next;\n\n while (p !== stop) {\n if (hx >= p.x && p.x >= mx && hx !== p.x &&\n pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\n tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n if ((tan < tanMin || (tan === tanMin && p.x > m.x)) && locallyInside(p, hole)) {\n m = p;\n tanMin = tan;\n }\n }\n\n p = p.next;\n }\n\n return m;\n}\n\n// interlink polygon nodes in z-order\nfunction indexCurve(start, minX, minY, invSize) {\n var p = start;\n do {\n if (p.z === null) p.z = zOrder(p.x, p.y, minX, minY, invSize);\n p.prevZ = p.prev;\n p.nextZ = p.next;\n p = p.next;\n } while (p !== start);\n\n p.prevZ.nextZ = null;\n p.prevZ = null;\n\n sortLinked(p);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n var i, p, q, e, tail, numMerges, pSize, qSize,\n inSize = 1;\n\n do {\n p = list;\n list = null;\n tail = null;\n numMerges = 0;\n\n while (p) {\n numMerges++;\n q = p;\n pSize = 0;\n for (i = 0; i < inSize; i++) {\n pSize++;\n q = q.nextZ;\n if (!q) break;\n }\n qSize = inSize;\n\n while (pSize > 0 || (qSize > 0 && q)) {\n\n if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n e = p;\n p = p.nextZ;\n pSize--;\n } else {\n e = q;\n q = q.nextZ;\n qSize--;\n }\n\n if (tail) tail.nextZ = e;\n else list = e;\n\n e.prevZ = tail;\n tail = e;\n }\n\n p = q;\n }\n\n tail.nextZ = null;\n inSize *= 2;\n\n } while (numMerges > 1);\n\n return list;\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\nfunction zOrder(x, y, minX, minY, invSize) {\n // coords are transformed into non-negative 15-bit integer range\n x = 32767 * (x - minX) * invSize;\n y = 32767 * (y - minY) * invSize;\n\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n// find the leftmost node of a polygon ring\nfunction getLeftmost(start) {\n var p = start,\n leftmost = start;\n do {\n if (p.x < leftmost.x) leftmost = p;\n p = p.next;\n } while (p !== start);\n\n return leftmost;\n}\n\n// check if a point lies within a convex triangle\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n return (cx - px) * (ay - py) - (ax - px) * (cy - py) >= 0 &&\n (ax - px) * (by - py) - (bx - px) * (ay - py) >= 0 &&\n (bx - px) * (cy - py) - (cx - px) * (by - py) >= 0;\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\nfunction isValidDiagonal(a, b) {\n return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) &&\n locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b);\n}\n\n// signed area of a triangle\nfunction area(p, q, r) {\n return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n}\n\n// check if two points are equal\nfunction equals(p1, p2) {\n return p1.x === p2.x && p1.y === p2.y;\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n if ((equals(p1, q1) && equals(p2, q2)) ||\n (equals(p1, q2) && equals(p2, q1))) return true;\n return area(p1, q1, p2) > 0 !== area(p1, q1, q2) > 0 &&\n area(p2, q2, p1) > 0 !== area(p2, q2, q1) > 0;\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(a, b) {\n var p = a;\n do {\n if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n intersects(p, p.next, a, b)) return true;\n p = p.next;\n } while (p !== a);\n\n return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n return area(a.prev, a, a.next) < 0 ?\n area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 :\n area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(a, b) {\n var p = a,\n inside = false,\n px = (a.x + b.x) / 2,\n py = (a.y + b.y) / 2;\n do {\n if (((p.y > py) !== (p.next.y > py)) && p.next.y !== p.y &&\n (px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x))\n inside = !inside;\n p = p.next;\n } while (p !== a);\n\n return inside;\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\nfunction splitPolygon(a, b) {\n var a2 = new Node(a.i, a.x, a.y),\n b2 = new Node(b.i, b.x, b.y),\n an = a.next,\n bp = b.prev;\n\n a.next = b;\n b.prev = a;\n\n a2.next = an;\n an.prev = a2;\n\n b2.next = a2;\n a2.prev = b2;\n\n bp.next = b2;\n b2.prev = bp;\n\n return b2;\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\nfunction insertNode(i, x, y, last) {\n var p = new Node(i, x, y);\n\n if (!last) {\n p.prev = p;\n p.next = p;\n\n } else {\n p.next = last.next;\n p.prev = last;\n last.next.prev = p;\n last.next = p;\n }\n return p;\n}\n\nfunction removeNode(p) {\n p.next.prev = p.prev;\n p.prev.next = p.next;\n\n if (p.prevZ) p.prevZ.nextZ = p.nextZ;\n if (p.nextZ) p.nextZ.prevZ = p.prevZ;\n}\n\nfunction Node(i, x, y) {\n // vertex index in coordinates array\n this.i = i;\n\n // vertex coordinates\n this.x = x;\n this.y = y;\n\n // previous and next vertex nodes in a polygon ring\n this.prev = null;\n this.next = null;\n\n // z-order curve value\n this.z = null;\n\n // previous and next nodes in z-order\n this.prevZ = null;\n this.nextZ = null;\n\n // indicates whether this is a steiner point\n this.steiner = false;\n}\n\n// return a percentage difference between the polygon area and its triangulation area;\n// used to verify correctness of triangulation\nearcut.deviation = function (data, holeIndices, dim, triangles) {\n var hasHoles = holeIndices && holeIndices.length;\n var outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n\n var polygonArea = Math.abs(signedArea(data, 0, outerLen, dim));\n if (hasHoles) {\n for (var i = 0, len = holeIndices.length; i < len; i++) {\n var start = holeIndices[i] * dim;\n var end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n polygonArea -= Math.abs(signedArea(data, start, end, dim));\n }\n }\n\n var trianglesArea = 0;\n for (i = 0; i < triangles.length; i += 3) {\n var a = triangles[i] * dim;\n var b = triangles[i + 1] * dim;\n var c = triangles[i + 2] * dim;\n trianglesArea += Math.abs(\n (data[a] - data[c]) * (data[b + 1] - data[a + 1]) -\n (data[a] - data[b]) * (data[c + 1] - data[a + 1]));\n }\n\n return polygonArea === 0 && trianglesArea === 0 ? 0 :\n Math.abs((trianglesArea - polygonArea) / polygonArea);\n};\n\nfunction signedArea(data, start, end, dim) {\n var sum = 0;\n for (var i = start, j = end - dim; i < end; i += dim) {\n sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n j = i;\n }\n return sum;\n}\n\n// turn a polygon in a multi-dimensional array form (e.g. as in GeoJSON) into a form Earcut accepts\nearcut.flatten = function (data) {\n var dim = data[0][0].length,\n result = {vertices: [], holes: [], dimensions: dim},\n holeIndex = 0;\n\n for (var i = 0; i < data.length; i++) {\n for (var j = 0; j < data[i].length; j++) {\n for (var d = 0; d < dim; d++) result.vertices.push(data[i][j][d]);\n }\n if (i > 0) {\n holeIndex += data[i - 1].length;\n result.holes.push(holeIndex);\n }\n }\n return result;\n};\n","/* npm main module */\n'use strict';\nexports.LatLonSpherical = require('./latlon-spherical.js');\nexports.LatLonEllipsoidal = require('./latlon-ellipsoidal.js');\n// merge vincenty methods into LatLonEllipsoidal\nvar V = require('./latlon-vincenty.js');\nfor (var prop in V) exports.LatLonEllipsoidal[prop] = V[prop];\nexports.LatLonVectors = require('./latlon-vectors.js');\nexports.Vector3d = require('./vector3d.js');\nexports.Utm = require('./utm.js');\nexports.Mgrs = require('./mgrs.js');\nexports.OsGridRef = require('./osgridref.js');\nexports.Dms = require('./dms.js');\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"search-bar\"},[_c('div',{staticClass:\"input-group\"},[_vm._m(0),_c('input',{ref:\"input\",staticClass:\"form-control\",attrs:{\"type\":\"text\",\"placeholder\":_vm.SR_Common.Searching},domProps:{\"value\":_vm.localValue},on:{\"input\":_vm.onInput,\"focus\":function($event){_vm.hasFocus = true},\"blur\":_vm.onFocusLoss}}),_c('InputClearButton',{attrs:{\"show\":!!_vm.value,\"right\":\"6px\"},on:{\"click\":_vm.clear}})],1)])}\nvar staticRenderFns = [function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('span',{staticClass:\"input-group-addon\",attrs:{\"id\":\"search-input-icon\"}},[_c('span',{staticClass:\"glyphicon glyphicon-search\",attrs:{\"aria-hidden\":\"true\"}})])}]\n\nexport { render, staticRenderFns }","\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!./SearchBar.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!./SearchBar.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SearchBar.vue?vue&type=template&id=747c6c04&scoped=true&lang=html&\"\nimport script from \"./SearchBar.vue?vue&type=script&lang=js&\"\nexport * from \"./SearchBar.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 \"747c6c04\",\n null\n \n)\n\nexport default component.exports","var createTopology = require('topojson-server').topology\nvar mergeTopology = require('topojson-client').merge\nvar dissolveLineStrings = require('geojson-linestring-dissolve')\nvar geomEach = require('@turf/meta').geomEach\nvar flatten = require('geojson-flatten')\n\nmodule.exports = dissolve\n\nfunction toArray (args) {\n if (!args.length) return []\n return Array.isArray(args[0]) ? args[0] : Array.prototype.slice.call(args)\n}\n\nfunction dissolvePolygons (geoms) {\n // Topojson modifies in place, so we need to deep clone first\n var objects = {\n geoms: {\n type: 'GeometryCollection',\n geometries: JSON.parse(JSON.stringify(geoms))\n }\n }\n var topo = createTopology(objects)\n return mergeTopology(topo, topo.objects.geoms.geometries)\n}\n\n// [GeoJSON] -> String|Null\nfunction getHomogenousType (geoms) {\n var type = null\n for (var i = 0; i < geoms.length; i++) {\n if (!type) {\n type = geoms[i].type\n } else if (type !== geoms[i].type) {\n return null\n }\n }\n return type\n}\n\n// Transform function: attempts to dissolve geojson objects where possible\n// [GeoJSON] -> GeoJSON geometry\nfunction dissolve () {\n // accept an array of geojson objects, or an argument list\n var objects = toArray(arguments)\n var geoms = objects.reduce(function (acc, o) {\n // flatten any Multi-geom into features of simple types\n var flat = flatten(o)\n if (!Array.isArray(flat)) flat = [flat]\n for (var i = 0; i < flat.length; i++) {\n // get an array of all flatten geometry objects\n geomEach(flat[i], function (geom) {\n acc.push(geom)\n })\n }\n return acc\n }, [])\n // Assert homogenity\n var type = getHomogenousType(geoms)\n if (!type) {\n throw new Error('List does not contain only homoegenous GeoJSON')\n }\n\n switch (type) {\n case 'LineString':\n return dissolveLineStrings(geoms)\n case 'Polygon':\n return dissolvePolygons(geoms)\n default:\n return geoms\n }\n}\n\n","var helpers = require('@turf/helpers');\nvar lineclip = require('lineclip');\nvar getCoords = require('@turf/invariant').getCoords;\nvar lineString = helpers.lineString;\nvar multiLineString = helpers.multiLineString;\nvar polygon = helpers.polygon;\nvar multiPolygon = helpers.multiPolygon;\n\n/**\n * Takes a {@link Feature} and a bbox and clips the feature to the bbox using [lineclip](https://github.com/mapbox/lineclip).\n * May result in degenerate edges when clipping Polygons.\n *\n * @name bboxClip\n * @param {Feature} feature feature to clip to the bbox\n * @param {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @returns {Feature} clipped Feature\n * @example\n * var bbox = [0, 0, 10, 10];\n * var poly = turf.polygon([[[2, 2], [8, 4], [12, 8], [3, 7], [2, 2]]]);\n *\n * var clipped = turf.bboxClip(poly, bbox);\n *\n * //addToMap\n * var addToMap = [bbox, poly, clipped]\n */\nmodule.exports = function (feature, bbox) {\n var geom = getGeom(feature);\n var coords = getCoords(feature);\n var properties = feature.properties;\n\n switch (geom) {\n case 'LineString':\n case 'MultiLineString':\n var lines = [];\n if (geom === 'LineString') coords = [coords];\n coords.forEach(function (line) {\n lineclip(line, bbox, lines);\n });\n if (lines.length === 1) return lineString(lines[0], properties);\n return multiLineString(lines, properties);\n case 'Polygon':\n return polygon(clipPolygon(coords, bbox), properties);\n case 'MultiPolygon':\n return multiPolygon(coords.map(function (polygon) {\n return clipPolygon(polygon, bbox);\n }), properties);\n default:\n throw new Error('geometry ' + geom + ' not supported');\n }\n};\n\nfunction clipPolygon(rings, bbox) {\n var outRings = [];\n for (var i = 0; i < rings.length; i++) {\n var clipped = lineclip.polygon(rings[i], bbox);\n if (clipped.length > 0) {\n if (clipped[0][0] !== clipped[clipped.length - 1][0] || clipped[0][1] !== clipped[clipped.length - 1][1]) {\n clipped.push(clipped[0]);\n }\n if (clipped.length >= 4) {\n outRings.push(clipped);\n }\n }\n }\n return outRings;\n}\n\nfunction getGeom(feature) {\n return (feature.geometry) ? feature.geometry.type : feature.type;\n}\n","var inside = require('@turf/inside');\nvar calcBbox = require('@turf/bbox');\nvar isPointOnLine = require('@turf/boolean-point-on-line');\nvar invariant = require('@turf/invariant');\nvar getGeom = invariant.getGeom;\nvar getCoords = invariant.getCoords;\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Boolean-contains returns True if the second geometry is completely contained by the first geometry.\n * The interiors of both geometries must intersect and, the interior and boundary of the secondary (geometry b)\n * must not intersect the exterior of the primary (geometry a).\n * Boolean-contains returns the exact opposite result of the `@turf/boolean-within`.\n *\n * @name booleanContains\n * @param {Geometry|Feature} feature1 GeoJSON Feature or Geometry\n * @param {Geometry|Feature} feature2 GeoJSON Feature or Geometry\n * @returns {boolean} true/false\n * @example\n * const line = turf.lineString([[1, 1], [1, 2], [1, 3], [1, 4]]);\n * const point = turf.point([1, 2]);\n *\n * turf.booleanContains(line, point);\n * //=true\n */\nmodule.exports = function (feature1, feature2) {\n var type1 = getGeomType(feature1);\n var type2 = getGeomType(feature2);\n var geom1 = getGeom(feature1);\n var geom2 = getGeom(feature2);\n var coords1 = getCoords(feature1);\n var coords2 = getCoords(feature2);\n\n switch (type1) {\n case 'Point':\n switch (type2) {\n case 'Point':\n return compareCoords(coords1, coords2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'MultiPoint':\n switch (type2) {\n case 'Point':\n return isPointInMultiPoint(geom1, geom2);\n case 'MultiPoint':\n return isMultiPointInMultiPoint(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'LineString':\n switch (type2) {\n case 'Point':\n return isPointOnLine(geom2, geom1, true);\n case 'LineString':\n return isLineOnLine(geom1, geom2);\n case 'MultiPoint':\n return isMultiPointOnLine(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'Polygon':\n switch (type2) {\n case 'Point':\n return inside(geom2, geom1, true);\n case 'LineString':\n return isLineInPoly(geom1, geom2);\n case 'Polygon':\n return isPolyInPoly(geom1, geom2);\n case 'MultiPoint':\n return isMultiPointInPoly(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n default:\n throw new Error('feature1 ' + type1 + ' geometry not supported');\n }\n};\n\nfunction isPointInMultiPoint(multiPoint, point) {\n var i;\n var output = false;\n for (i = 0; i < multiPoint.coordinates.length; i++) {\n if (compareCoords(multiPoint.coordinates[i], point.coordinates)) {\n output = true;\n break;\n }\n }\n return output;\n}\n\nfunction isMultiPointInMultiPoint(multiPoint1, multiPoint2) {\n for (var i = 0; i < multiPoint2.coordinates.length; i++) {\n var matchFound = false;\n for (var i2 = 0; i2 < multiPoint1.coordinates.length; i2++) {\n if (compareCoords(multiPoint2.coordinates[i], multiPoint1.coordinates[i2])) {\n matchFound = true;\n break;\n }\n }\n if (!matchFound) {\n return false;\n }\n }\n return true;\n}\n\n\nfunction isMultiPointOnLine(lineString, multiPoint) {\n var haveFoundInteriorPoint = false;\n for (var i = 0; i < multiPoint.coordinates.length; i++) {\n if (isPointOnLine(multiPoint.coordinates[i], lineString, true)) {\n haveFoundInteriorPoint = true;\n }\n if (!isPointOnLine(multiPoint.coordinates[i], lineString)) {\n return false;\n }\n }\n if (haveFoundInteriorPoint) {\n return true;\n }\n return false;\n}\n\nfunction isMultiPointInPoly(polygon, multiPoint) {\n for (var i = 0; i < multiPoint.coordinates.length; i++) {\n if (!inside(multiPoint.coordinates[i], polygon, true)) {\n return false;\n }\n }\n return true;\n}\n\nfunction isLineOnLine(lineString1, lineString2) {\n var haveFoundInteriorPoint = false;\n for (var i = 0; i < lineString2.coordinates.length; i++) {\n if (isPointOnLine({type: 'Point', coordinates: lineString2.coordinates[i]}, lineString1, true)) {\n haveFoundInteriorPoint = true;\n }\n if (!isPointOnLine({type: 'Point', coordinates: lineString2.coordinates[i]}, lineString1, false)) {\n return false;\n }\n }\n return haveFoundInteriorPoint;\n}\n\nfunction isLineInPoly(polygon, linestring) {\n var output = false;\n var i = 0;\n\n var polyBbox = calcBbox(polygon);\n var lineBbox = calcBbox(linestring);\n if (!doBBoxOverlap(polyBbox, lineBbox)) {\n return false;\n }\n for (i; i < linestring.coordinates.length - 1; i++) {\n var midPoint = getMidpoint(linestring.coordinates[i], linestring.coordinates[i + 1]);\n if (inside({type: 'Point', coordinates: midPoint}, polygon, true)) {\n output = true;\n break;\n }\n }\n return output;\n}\n\n/**\n * Is Polygon2 in Polygon1\n * Only takes into account outer rings\n *\n * @private\n * @param {Geometry|Feature} feature1 Polygon1\n * @param {Geometry|Feature} feature2 Polygon2\n * @returns {boolean} true/false\n */\nfunction isPolyInPoly(feature1, feature2) {\n var poly1Bbox = calcBbox(feature1);\n var poly2Bbox = calcBbox(feature2);\n if (!doBBoxOverlap(poly1Bbox, poly2Bbox)) {\n return false;\n }\n for (var i = 0; i < feature2.coordinates[0].length; i++) {\n if (!inside(feature2.coordinates[0][i], feature1)) {\n return false;\n }\n }\n return true;\n}\n\nfunction doBBoxOverlap(bbox1, bbox2) {\n if (bbox1[0] > bbox2[0]) return false;\n if (bbox1[2] < bbox2[2]) return false;\n if (bbox1[1] > bbox2[1]) return false;\n if (bbox1[3] < bbox2[3]) return false;\n return true;\n}\n\n/**\n * compareCoords\n *\n * @private\n * @param {[number, number]} pair1 point [x,y]\n * @param {[number, number]} pair2 point [x,y]\n * @returns {boolean} true/false if coord pairs match\n */\nfunction compareCoords(pair1, pair2) {\n return pair1[0] === pair2[0] && pair1[1] === pair2[1];\n}\n\nfunction getMidpoint(pair1, pair2) {\n return [(pair1[0] + pair2[0]) / 2, (pair1[1] + pair2[1]) / 2];\n}\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./NumericInput.vue?vue&type=style&index=0&id=505bcb48&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./NumericInput.vue?vue&type=style&index=0&id=505bcb48&lang=scss&scoped=true&\"","var getCoords = require('@turf/invariant').getCoords;\nvar helpers = require('@turf/helpers');\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Finds the tangents of a {@link Polygon|(Multi)Polygon} from a {@link Point}.\n *\n * @name polygonTangents\n * @param {Feature} point to calculate the tangent points from\n * @param {Feature} polygon to get tangents from\n * @returns {FeatureCollection} Feature Collection containing the two tangent points\n * @example\n * var polygon = turf.polygon([[[11, 0], [22, 4], [31, 0], [31, 11], [21, 15], [11, 11], [11, 0]]]);\n * var point = turf.point([61, 5]);\n *\n * var tangents = turf.polygonTangents(point, polygon)\n *\n * //addToMap\n * var addToMap = [tangents, point, polygon];\n */\nmodule.exports = function (point, polygon) {\n var eprev;\n var enext;\n var rtan;\n var ltan;\n var pointCoords = getCoords(point);\n var polyCoords = getCoords(polygon);\n\n var type = getGeomType(polygon);\n switch (type) {\n case 'Polygon':\n rtan = 0;\n ltan = 0;\n eprev = isLeft(polyCoords[0][0], polyCoords[0][1], pointCoords);\n var out = processPolygon(polyCoords[0], pointCoords, eprev, enext, rtan, ltan);\n rtan = out[0];\n ltan = out[1];\n break;\n case 'MultiPolygon':\n rtan = 0;\n ltan = 0;\n eprev = isLeft(polyCoords[0][0][0], polyCoords[0][0][1], pointCoords);\n polyCoords.forEach(function (ring) {\n var out = processPolygon(ring[0], pointCoords, eprev, enext, rtan, ltan);\n rtan = out[0];\n ltan = out[1];\n });\n break;\n }\n return featureCollection([helpers.point(rtan), helpers.point(ltan)]);\n};\n\nfunction processPolygon(polygonCoords, ptCoords, eprev, enext, rtan, ltan) {\n for (var i = 0; i < polygonCoords.length; i++) {\n var currentCoords = polygonCoords[i];\n var nextCoordPair = polygonCoords[i + 1];\n if (i === polygonCoords.length - 1) {\n nextCoordPair = polygonCoords[0];\n }\n enext = isLeft(currentCoords, nextCoordPair, ptCoords);\n if (eprev <= 0 && enext > 0) {\n if (!isBelow(ptCoords, currentCoords, rtan)) {\n rtan = currentCoords;\n }\n }\n if (eprev > 0 && enext <= 0) {\n if (!isAbove(ptCoords, currentCoords, ltan)) {\n ltan = currentCoords;\n }\n }\n eprev = enext;\n }\n return [rtan, ltan];\n}\n\nfunction isAbove(point1, point2, point3) {\n return isLeft(point1, point2, point3) >= 0;\n}\n\nfunction isBelow(point1, point2, point3) {\n return isLeft(point1, point2, point3) <= 0;\n}\n\nfunction isLeft(point1, point2, point3) {\n return (point2[0] - point1[0]) * (point3[1] - point1[1]) - (point3[0] - point1[0]) * (point2[1] - point1[1]);\n}\n\n// will be included in @turf/invariant\nfunction getGeomType(geojson) {\n return (geojson.geometry) ? geojson.geometry.type : geojson.type;\n}\n","//http://en.wikipedia.org/wiki/Haversine_formula\n//http://www.movable-type.co.uk/scripts/latlong.html\nvar getCoord = require('@turf/invariant').getCoord;\nvar helpers = require('@turf/helpers');\nvar point = helpers.point;\nvar distanceToRadians = helpers.distanceToRadians;\n\n/**\n * Takes a {@link Point} and calculates the location of a destination point given a distance in degrees, radians, miles, or kilometers; and bearing in degrees. This uses the [Haversine formula](http://en.wikipedia.org/wiki/Haversine_formula) to account for global curvature.\n *\n * @name destination\n * @param {Geometry|Feature|Array} origin starting point\n * @param {number} distance distance from the origin point\n * @param {number} bearing ranging from -180 to 180\n * @param {string} [units=kilometers] miles, kilometers, degrees, or radians\n * @returns {Feature} destination point\n * @example\n * var point = turf.point([-75.343, 39.984]);\n * var distance = 50;\n * var bearing = 90;\n * var units = 'miles';\n *\n * var destination = turf.destination(point, distance, bearing, units);\n *\n * //addToMap\n * var addToMap = [point, destination]\n * destination.properties['marker-color'] = '#f00';\n * point.properties['marker-color'] = '#0f0';\n */\nmodule.exports = function (origin, distance, bearing, units) {\n var degrees2radians = Math.PI / 180;\n var radians2degrees = 180 / Math.PI;\n var coordinates1 = getCoord(origin);\n var longitude1 = degrees2radians * coordinates1[0];\n var latitude1 = degrees2radians * coordinates1[1];\n var bearing_rad = degrees2radians * bearing;\n\n var radians = distanceToRadians(distance, units);\n\n var latitude2 = Math.asin(Math.sin(latitude1) * Math.cos(radians) +\n Math.cos(latitude1) * Math.sin(radians) * Math.cos(bearing_rad));\n var longitude2 = longitude1 + Math.atan2(Math.sin(bearing_rad) * Math.sin(radians) * Math.cos(latitude1),\n Math.cos(radians) - Math.sin(latitude1) * Math.sin(latitude2));\n\n return point([radians2degrees * longitude2, radians2degrees * latitude2]);\n};\n","var meta = require('@turf/meta');\nvar helpers = require('@turf/helpers');\nvar simplepolygon = require('simplepolygon');\nvar flattenEach = meta.flattenEach;\nvar featureEach = meta.featureEach;\nvar polygon = helpers.polygon;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a kinked polygon and returns a feature collection of polygons that have no kinks.\n * Uses [simplepolygon](https://github.com/mclaeysb/simplepolygon) internally.\n *\n * @name unkinkPolygon\n * @param {FeatureCollection|Feature} geojson GeoJSON Polygon or MultiPolygon\n * @returns {FeatureCollection} Unkinked polygons\n * @example\n * var poly = turf.polygon([[[0, 0], [2, 0], [0, 2], [2, 2], [0, 0]]]);\n *\n * var result = turf.unkinkPolygon(poly);\n *\n * //addToMap\n * var addToMap = [poly, result]\n */\nmodule.exports = function (geojson) {\n var features = [];\n flattenEach(geojson, function (feature) {\n if (feature.geometry.type !== 'Polygon') return;\n featureEach(simplepolygon(feature), function (poly) {\n features.push(polygon(poly.geometry.coordinates, feature.properties));\n });\n });\n return featureCollection(features);\n};\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Geodesy tools for an ellipsoidal earth model (c) Chris Veness 2005-2016 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-convert-coords.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-latlon-ellipsoidal.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var Vector3d = require('./vector3d.js'); // ≡ import Vector3d from 'vector3d.js'\nif (typeof module!='undefined' && module.exports) var Dms = require('./dms.js'); // ≡ import Dms from 'dms.js'\n\n\n/**\n * Library of geodesy functions for operations on an ellipsoidal earth model.\n *\n * Includes ellipsoid parameters and datums for different coordinate systems, and methods for\n * converting between them and to cartesian coordinates.\n *\n * q.v. Ordnance Survey ‘A guide to coordinate systems in Great Britain’ Section 6\n * www.ordnancesurvey.co.uk/docs/support/guide-coordinate-systems-great-britain.pdf.\n *\n * @module latlon-ellipsoidal\n * @requires dms\n */\n\n\n/**\n * Creates lat/lon (polar) point with latitude & longitude values, on a specified datum.\n *\n * @constructor\n * @param {number} lat - Geodetic latitude in degrees.\n * @param {number} lon - Longitude in degrees.\n * @param {LatLon.datum} [datum=WGS84] - Datum this point is defined within.\n *\n * @example\n * var p1 = new LatLon(51.4778, -0.0016, LatLon.datum.WGS84);\n */\nfunction LatLon(lat, lon, datum) {\n // allow instantiation without 'new'\n if (!(this instanceof LatLon)) return new LatLon(lat, lon, datum);\n\n if (datum === undefined) datum = LatLon.datum.WGS84;\n\n this.lat = Number(lat);\n this.lon = Number(lon);\n this.datum = datum;\n}\n\n\n/**\n * Ellipsoid parameters; major axis (a), minor axis (b), and flattening (f) for each ellipsoid.\n */\nLatLon.ellipsoid = {\n WGS84: { a: 6378137, b: 6356752.314245, f: 1/298.257223563 },\n Airy1830: { a: 6377563.396, b: 6356256.909, f: 1/299.3249646 },\n AiryModified: { a: 6377340.189, b: 6356034.448, f: 1/299.3249646 },\n Bessel1841: { a: 6377397.155, b: 6356078.962818, f: 1/299.1528128 },\n Clarke1866: { a: 6378206.4, b: 6356583.8, f: 1/294.978698214 },\n Clarke1880IGN: { a: 6378249.2, b: 6356515.0, f: 1/293.466021294 },\n GRS80: { a: 6378137, b: 6356752.314140, f: 1/298.257222101 },\n Intl1924: { a: 6378388, b: 6356911.946, f: 1/297 }, // aka Hayford\n WGS72: { a: 6378135, b: 6356750.5, f: 1/298.26 },\n};\n\n/**\n * Datums; with associated ellipsoid, and Helmert transform parameters to convert from WGS 84 into\n * given datum.\n *\n * Note that precision of various datums will vary, and WGS-84 (original) is not defined to be\n * accurate to better than ±1 metre. No transformation should be assumed to be accurate to better\n * than a meter; for many datums somewhat less.\n */\nLatLon.datum = {\n // transforms: t in metres, s in ppm, r in arcseconds tx ty tz s rx ry rz\n ED50: { ellipsoid: LatLon.ellipsoid.Intl1924, transform: [ 89.5, 93.8, 123.1, -1.2, 0.0, 0.0, 0.156 ] },\n Irl1975: { ellipsoid: LatLon.ellipsoid.AiryModified, transform: [ -482.530, 130.596, -564.557, -8.150, -1.042, -0.214, -0.631 ] },\n NAD27: { ellipsoid: LatLon.ellipsoid.Clarke1866, transform: [ 8, -160, -176, 0, 0, 0, 0 ] },\n NAD83: { ellipsoid: LatLon.ellipsoid.GRS80, transform: [ 1.004, -1.910, -0.515, -0.0015, 0.0267, 0.00034, 0.011 ] },\n NTF: { ellipsoid: LatLon.ellipsoid.Clarke1880IGN, transform: [ 168, 60, -320, 0, 0, 0, 0 ] },\n OSGB36: { ellipsoid: LatLon.ellipsoid.Airy1830, transform: [ -446.448, 125.157, -542.060, 20.4894, -0.1502, -0.2470, -0.8421 ] },\n Potsdam: { ellipsoid: LatLon.ellipsoid.Bessel1841, transform: [ -582, -105, -414, -8.3, 1.04, 0.35, -3.08 ] },\n TokyoJapan: { ellipsoid: LatLon.ellipsoid.Bessel1841, transform: [ 148, -507, -685, 0, 0, 0, 0 ] },\n WGS72: { ellipsoid: LatLon.ellipsoid.WGS72, transform: [ 0, 0, -4.5, -0.22, 0, 0, 0.554 ] },\n WGS84: { ellipsoid: LatLon.ellipsoid.WGS84, transform: [ 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0 ] },\n};\n/* sources:\n * - ED50: www.gov.uk/guidance/oil-and-gas-petroleum-operations-notices#pon-4\n * - Irl1975: www.osi.ie/wp-content/uploads/2015/05/transformations_booklet.pdf\n * ... note: many sources have opposite sign to rotations - to be checked!\n * - NAD27: en.wikipedia.org/wiki/Helmert_transformation\n * - NAD83: (2009); www.uvm.edu/giv/resources/WGS84_NAD83.pdf\n * ... note: functionally ≡ WGS84 - if you *really* need to convert WGS84<->NAD83, you need more knowledge than this!\n * - NTF: Nouvelle Triangulation Francaise geodesie.ign.fr/contenu/fichiers/Changement_systeme_geodesique.pdf\n * - OSGB36: www.ordnancesurvey.co.uk/docs/support/guide-coordinate-systems-great-britain.pdf\n * - Potsdam: kartoweb.itc.nl/geometrics/Coordinate%20transformations/coordtrans.html\n * - TokyoJapan: www.geocachingtoolbox.com?page=datumEllipsoidDetails\n * - WGS72: www.icao.int/safety/pbn/documentation/eurocontrol/eurocontrol wgs 84 implementation manual.pdf\n *\n * more transform parameters are available from earth-info.nga.mil/GandG/coordsys/datums/NATO_DT.pdf,\n * www.fieldenmaps.info/cconv/web/cconv_params.js\n */\n\n\n/**\n * Converts ‘this’ lat/lon coordinate to new coordinate system.\n *\n * @param {LatLon.datum} toDatum - Datum this coordinate is to be converted to.\n * @returns {LatLon} This point converted to new datum.\n *\n * @example\n * var pWGS84 = new LatLon(51.4778, -0.0016, LatLon.datum.WGS84);\n * var pOSGB = pWGS84.convertDatum(LatLon.datum.OSGB36); // 51.4773°N, 000.0000°E\n */\nLatLon.prototype.convertDatum = function(toDatum) {\n var oldLatLon = this;\n var transform = null;\n\n if (oldLatLon.datum == LatLon.datum.WGS84) {\n // converting from WGS 84\n transform = toDatum.transform;\n }\n if (toDatum == LatLon.datum.WGS84) {\n // converting to WGS 84; use inverse transform (don't overwrite original!)\n transform = [];\n for (var p=0; p<7; p++) transform[p] = -oldLatLon.datum.transform[p];\n }\n if (transform == null) {\n // neither this.datum nor toDatum are WGS84: convert this to WGS84 first\n oldLatLon = this.convertDatum(LatLon.datum.WGS84);\n transform = toDatum.transform;\n }\n\n var oldCartesian = oldLatLon.toCartesian(); // convert polar to cartesian...\n var newCartesian = oldCartesian.applyTransform(transform); // ...apply transform...\n var newLatLon = newCartesian.toLatLonE(toDatum); // ...and convert cartesian to polar\n\n return newLatLon;\n};\n\n\n/**\n * Converts ‘this’ point from (geodetic) latitude/longitude coordinates to (geocentric) cartesian\n * (x/y/z) coordinates.\n *\n * @returns {Vector3d} Vector pointing to lat/lon point, with x, y, z in metres from earth centre.\n */\nLatLon.prototype.toCartesian = function() {\n var φ = this.lat.toRadians(), λ = this.lon.toRadians();\n var h = 0; // height above ellipsoid - not currently used\n var a = this.datum.ellipsoid.a, f = this.datum.ellipsoid.f;\n\n var sinφ = Math.sin(φ), cosφ = Math.cos(φ);\n var sinλ = Math.sin(λ), cosλ = Math.cos(λ);\n\n var eSq = 2*f - f*f; // 1st eccentricity squared ≡ (a²-b²)/a²\n var ν = a / Math.sqrt(1 - eSq*sinφ*sinφ); // radius of curvature in prime vertical\n\n var x = (ν+h) * cosφ * cosλ;\n var y = (ν+h) * cosφ * sinλ;\n var z = (ν*(1-eSq)+h) * sinφ;\n\n var point = new Vector3d(x, y, z);\n\n return point;\n};\n\n\n/**\n * Converts ‘this’ (geocentric) cartesian (x/y/z) point to (ellipsoidal geodetic) latitude/longitude\n * coordinates on specified datum.\n *\n * Uses Bowring’s (1985) formulation for μm precision in concise form.\n *\n * @param {LatLon.datum.transform} datum - Datum to use when converting point.\n */\nVector3d.prototype.toLatLonE = function(datum) {\n var x = this.x, y = this.y, z = this.z;\n var a = datum.ellipsoid.a, b = datum.ellipsoid.b, f = datum.ellipsoid.f;\n\n var e2 = 2*f - f*f; // 1st eccentricity squared ≡ (a²-b²)/a²\n var ε2 = e2 / (1-e2); // 2nd eccentricity squared ≡ (a²-b²)/b²\n var p = Math.sqrt(x*x + y*y); // distance from minor axis\n var R = Math.sqrt(p*p + z*z); // polar radius\n\n // parametric latitude (Bowring eqn 17, replacing tanβ = z·a / p·b)\n var tanβ = (b*z)/(a*p) * (1+ε2*b/R);\n var sinβ = tanβ / Math.sqrt(1+tanβ*tanβ);\n var cosβ = sinβ / tanβ;\n\n // geodetic latitude (Bowring eqn 18: tanφ = z+ε²bsin³β / p−e²cos³β)\n var φ = isNaN(cosβ) ? 0 : Math.atan2(z + ε2*b*sinβ*sinβ*sinβ, p - e2*a*cosβ*cosβ*cosβ);\n\n // longitude\n var λ = Math.atan2(y, x);\n\n // height above ellipsoid (Bowring eqn 7) [not currently used]\n var sinφ = Math.sin(φ), cosφ = Math.cos(φ);\n var ν = a/Math.sqrt(1-e2*sinφ*sinφ); // length of the normal terminated by the minor axis\n var h = p*cosφ + z*sinφ - (a*a/ν);\n\n var point = new LatLon(φ.toDegrees(), λ.toDegrees(), datum);\n\n return point;\n};\n\n/**\n * Applies Helmert transform to ‘this’ point using transform parameters t.\n *\n * @private\n * @param {number[]} t - Transform to apply to this point.\n * @returns {Vector3} Transformed point.\n */\nVector3d.prototype.applyTransform = function(t) {\n // this point\n var x1 = this.x, y1 = this.y, z1 = this.z;\n\n // transform parameters\n var tx = t[0]; // x-shift\n var ty = t[1]; // y-shift\n var tz = t[2]; // z-shift\n var s1 = t[3]/1e6 + 1; // scale: normalise parts-per-million to (s+1)\n var rx = (t[4]/3600).toRadians(); // x-rotation: normalise arcseconds to radians\n var ry = (t[5]/3600).toRadians(); // y-rotation: normalise arcseconds to radians\n var rz = (t[6]/3600).toRadians(); // z-rotation: normalise arcseconds to radians\n\n // apply transform\n var x2 = tx + x1*s1 - y1*rz + z1*ry;\n var y2 = ty + x1*rz + y1*s1 - z1*rx;\n var z2 = tz - x1*ry + y1*rx + z1*s1;\n\n return new Vector3d(x2, y2, z2);\n};\n\n\n/**\n * Returns a string representation of ‘this’ point, formatted as degrees, degrees+minutes, or\n * degrees+minutes+seconds.\n *\n * @param {string} [format=dms] - Format point as 'd', 'dm', 'dms'.\n * @param {number} [dp=0|2|4] - Number of decimal places to use - default 0 for dms, 2 for dm, 4 for d.\n * @returns {string} Comma-separated latitude/longitude.\n */\nLatLon.prototype.toString = function(format, dp) {\n return Dms.toLat(this.lat, format, dp) + ', ' + Dms.toLon(this.lon, format, dp);\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n/** Extend Number object with method to convert numeric degrees to radians */\nif (Number.prototype.toRadians === undefined) {\n Number.prototype.toRadians = function() { return this * Math.PI / 180; };\n}\n\n/** Extend Number object with method to convert radians to numeric (signed) degrees */\nif (Number.prototype.toDegrees === undefined) {\n Number.prototype.toDegrees = function() { return this * 180 / Math.PI; };\n}\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = LatLon, module.exports.Vector3d = Vector3d; // ≡ export { LatLon as default, Vector3d }\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SatelliteImageSelection.vue?vue&type=style&index=0&id=b55de902&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SatelliteImageSelection.vue?vue&type=style&index=0&id=b55de902&lang=scss&scoped=true&\"","module.exports.RADIUS = 6378137;\nmodule.exports.FLATTENING = 1/298.257223563;\nmodule.exports.POLAR_RADIUS = 6356752.3142;\n","var meta = require('@turf/meta');\n\n/**\n * Combines a {@link FeatureCollection} of {@link Point}, {@link LineString}, or {@link Polygon} features\n * into {@link MultiPoint}, {@link MultiLineString}, or {@link MultiPolygon} features.\n *\n * @name combine\n * @param {FeatureCollection} fc a FeatureCollection of any type\n * @returns {FeatureCollection} a FeatureCollection of corresponding type to input\n * @example\n * var fc = turf.featureCollection([\n * turf.point([19.026432, 47.49134]),\n * turf.point([19.074497, 47.509548])\n * ]);\n *\n * var combined = turf.combine(fc);\n *\n * //addToMap\n * var addToMap = [combined]\n */\nmodule.exports = function (fc) {\n var groups = {\n MultiPoint: {coordinates: [], properties: []},\n MultiLineString: {coordinates: [], properties: []},\n MultiPolygon: {coordinates: [], properties: []}\n };\n\n var multiMapping = Object.keys(groups).reduce(function (memo, item) {\n memo[item.replace('Multi', '')] = item;\n return memo;\n }, {});\n\n function addToGroup(feature, key, multi) {\n if (!multi) {\n groups[key].coordinates.push(feature.geometry.coordinates);\n } else {\n groups[key].coordinates = groups[key].coordinates.concat(feature.geometry.coordinates);\n }\n groups[key].properties.push(feature.properties);\n }\n\n meta.featureEach(fc, function (feature) {\n if (!feature.geometry) return;\n if (groups[feature.geometry.type]) {\n addToGroup(feature, feature.geometry.type, true);\n } else if (multiMapping[feature.geometry.type]) {\n addToGroup(feature, multiMapping[feature.geometry.type], false);\n }\n });\n\n return {\n type: 'FeatureCollection',\n features: Object.keys(groups)\n .filter(function (key) {\n return groups[key].coordinates.length;\n })\n .sort()\n .map(function (key) {\n return {\n type: 'Feature',\n properties: {\n collectedProperties: groups[key].properties\n },\n geometry: {\n type: key,\n coordinates: groups[key].coordinates\n }\n };\n })\n };\n};\n","var rbush = require('rbush');\nvar meta = require('@turf/meta');\nvar featureEach = meta.featureEach;\nvar coordEach = meta.coordEach;\n\n/**\n * GeoJSON implementation of [RBush](https://github.com/mourner/rbush#rbush) spatial index.\n *\n * @name rbush\n * @param {number} [maxEntries=9] defines the maximum number of entries in a tree node. 9 (used by default) is a\n * reasonable choice for most applications. Higher value means faster insertion and slower search, and vice versa.\n * @returns {RBush} GeoJSON RBush\n * @example\n * var rbush = require('geojson-rbush')\n * var tree = rbush()\n */\nmodule.exports = function (maxEntries) {\n var tree = rbush(maxEntries);\n /**\n * [insert](https://github.com/mourner/rbush#data-format)\n *\n * @param {Feature} feature insert single GeoJSON Feature\n * @returns {RBush} GeoJSON RBush\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]\n * }\n * }\n * tree.insert(polygon)\n */\n tree.insert = function (feature) {\n if (Array.isArray(feature)) {\n var bbox = feature;\n feature = bboxPolygon(bbox);\n feature.bbox = bbox;\n } else {\n feature.bbox = feature.bbox ? feature.bbox : turfBBox(feature);\n }\n return rbush.prototype.insert.call(this, feature);\n };\n\n /**\n * [load](https://github.com/mourner/rbush#bulk-inserting-data)\n *\n * @param {BBox[]|FeatureCollection} features load entire GeoJSON FeatureCollection\n * @returns {RBush} GeoJSON RBush\n * @example\n * var polygons = {\n * \"type\": \"FeatureCollection\",\n * \"features\": [\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]\n * }\n * },\n * {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-93, 32], [-83, 32], [-83, 39], [-93, 39], [-93, 32]]]\n * }\n * }\n * ]\n * }\n * tree.load(polygons)\n */\n tree.load = function (features) {\n var load = [];\n // Load an Array of BBox\n if (Array.isArray(features)) {\n features.forEach(function (bbox) {\n var feature = bboxPolygon(bbox);\n feature.bbox = bbox;\n load.push(feature);\n });\n } else {\n // Load FeatureCollection\n featureEach(features, function (feature) {\n feature.bbox = feature.bbox ? feature.bbox : turfBBox(feature);\n load.push(feature);\n });\n }\n return rbush.prototype.load.call(this, load);\n };\n\n /**\n * [remove](https://github.com/mourner/rbush#removing-data)\n *\n * @param {BBox|Feature} feature remove single GeoJSON Feature\n * @returns {RBush} GeoJSON RBush\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]\n * }\n * }\n * tree.remove(polygon)\n */\n tree.remove = function (feature) {\n if (Array.isArray(feature)) {\n var bbox = feature;\n feature = bboxPolygon(bbox);\n feature.bbox = bbox;\n }\n return rbush.prototype.remove.call(this, feature);\n };\n\n /**\n * [clear](https://github.com/mourner/rbush#removing-data)\n *\n * @returns {RBush} GeoJSON Rbush\n * @example\n * tree.clear()\n */\n tree.clear = function () {\n return rbush.prototype.clear.call(this);\n };\n\n /**\n * [search](https://github.com/mourner/rbush#search)\n *\n * @param {BBox|FeatureCollection|Feature} geojson search with GeoJSON\n * @returns {FeatureCollection} all features that intersects with the given GeoJSON.\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]\n * }\n * }\n * tree.search(polygon)\n */\n tree.search = function (geojson) {\n var features = rbush.prototype.search.call(this, this.toBBox(geojson));\n return {\n type: 'FeatureCollection',\n features: features\n };\n };\n\n /**\n * [collides](https://github.com/mourner/rbush#collisions)\n *\n * @param {BBox|FeatureCollection|Feature} geojson collides with GeoJSON\n * @returns {boolean} true if there are any items intersecting the given GeoJSON, otherwise false.\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]\n * }\n * }\n * tree.collides(polygon)\n */\n tree.collides = function (geojson) {\n return rbush.prototype.collides.call(this, this.toBBox(geojson));\n };\n\n /**\n * [all](https://github.com/mourner/rbush#search)\n *\n * @returns {FeatureCollection} all the features in RBush\n * @example\n * tree.all()\n * //=FeatureCollection\n */\n tree.all = function () {\n var features = rbush.prototype.all.call(this);\n return {\n type: 'FeatureCollection',\n features: features\n };\n };\n\n /**\n * [toJSON](https://github.com/mourner/rbush#export-and-import)\n *\n * @returns {any} export data as JSON object\n * @example\n * var exported = tree.toJSON()\n * //=JSON object\n */\n tree.toJSON = function () {\n return rbush.prototype.toJSON.call(this);\n };\n\n /**\n * [fromJSON](https://github.com/mourner/rbush#export-and-import)\n *\n * @param {any} json import previously exported data\n * @returns {RBush} GeoJSON RBush\n * @example\n * var exported = {\n * \"children\": [\n * {\n * \"type\": \"Feature\",\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 50]\n * },\n * \"properties\": {},\n * \"bbox\": [110, 50, 110, 50]\n * }\n * ],\n * \"height\": 1,\n * \"leaf\": true,\n * \"minX\": 110,\n * \"minY\": 50,\n * \"maxX\": 110,\n * \"maxY\": 50\n * }\n * tree.fromJSON(exported)\n */\n tree.fromJSON = function (json) {\n return rbush.prototype.fromJSON.call(this, json);\n };\n\n /**\n * Converts GeoJSON to {minX, minY, maxX, maxY} schema\n *\n * @private\n * @param {BBox|FeatureCollectio|Feature} geojson feature(s) to retrieve BBox from\n * @returns {Object} converted to {minX, minY, maxX, maxY}\n */\n tree.toBBox = function (geojson) {\n var bbox;\n if (geojson.bbox) bbox = geojson.bbox;\n else if (Array.isArray(geojson) && geojson.length === 4) bbox = geojson;\n else bbox = turfBBox(geojson);\n\n return {\n minX: bbox[0],\n minY: bbox[1],\n maxX: bbox[2],\n maxY: bbox[3]\n };\n };\n return tree;\n};\n\n/**\n * Takes a bbox and returns an equivalent {@link Polygon|polygon}.\n *\n * @private\n * @name bboxPolygon\n * @param {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @returns {Feature} a Polygon representation of the bounding box\n * @example\n * var bbox = [0, 0, 10, 10];\n *\n * var poly = turf.bboxPolygon(bbox);\n *\n * //addToMap\n * var addToMap = [poly]\n */\nfunction bboxPolygon(bbox) {\n var lowLeft = [bbox[0], bbox[1]];\n var topLeft = [bbox[0], bbox[3]];\n var topRight = [bbox[2], bbox[3]];\n var lowRight = [bbox[2], bbox[1]];\n var coordinates = [[lowLeft, lowRight, topRight, topLeft, lowLeft]];\n\n return {\n type: 'Feature',\n bbox: bbox,\n properties: {},\n geometry: {\n type: 'Polygon',\n coordinates: coordinates\n }\n };\n}\n\n/**\n * Takes a set of features, calculates the bbox of all input features, and returns a bounding box.\n *\n * @private\n * @name bbox\n * @param {FeatureCollection|Feature} geojson input features\n * @returns {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @example\n * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]]);\n * var bbox = turf.bbox(line);\n * var bboxPolygon = turf.bboxPolygon(bbox);\n *\n * //addToMap\n * var addToMap = [line, bboxPolygon]\n */\nfunction turfBBox(geojson) {\n var bbox = [Infinity, Infinity, -Infinity, -Infinity];\n coordEach(geojson, function (coord) {\n if (bbox[0] > coord[0]) bbox[0] = coord[0];\n if (bbox[1] > coord[1]) bbox[1] = coord[1];\n if (bbox[2] < coord[0]) bbox[2] = coord[0];\n if (bbox[3] < coord[1]) bbox[3] = coord[1];\n });\n return bbox;\n}\n","var distance = require('@turf/distance');\nvar turfBBox = require('@turf/bbox');\nvar helpers = require('@turf/helpers');\nvar point = helpers.point;\nvar polygon = helpers.polygon;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Creates a square grid from a bounding box, {@link Feature} or {@link FeatureCollection}.\n *\n * @name squareGrid\n * @param {Array|FeatureCollection|Feature} bbox extent in [minX, minY, maxX, maxY] order\n * @param {number} cellSize width of each cell\n * @param {string} [units=kilometers] used in calculating cellSize, can be degrees, radians, miles, or kilometers\n * @param {boolean} [completelyWithin=false] adjust width & height cellSize to fit exactly within bbox\n * @returns {FeatureCollection} grid a grid of polygons\n * @example\n * var bbox = [-95, 30 ,-85, 40];\n * var cellSize = 50;\n * var units = 'miles';\n *\n * var squareGrid = turf.squareGrid(bbox, cellSize, units);\n *\n * //addToMap\n * var addToMap = [squareGrid]\n */\nmodule.exports = function squareGrid(bbox, cellSize, units, completelyWithin) {\n var results = [];\n\n // validation\n if (!bbox) throw new Error('bbox is required');\n if (!Array.isArray(bbox)) bbox = turfBBox(bbox); // Convert GeoJSON to bbox\n if (bbox.length !== 4) throw new Error('bbox must contain 4 numbers');\n\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n\n // distance\n var xDistance = distance(point([west, south]), point([east, south]), units);\n var yDistance = distance(point([west, south]), point([west, north]), units);\n\n // rows & columns\n var columns = Math.ceil(xDistance / cellSize);\n var rows = Math.ceil(yDistance / cellSize);\n\n // columns | width | x\n var xFraction = cellSize / xDistance;\n var cellWidth = xFraction * (east - west);\n if (completelyWithin === true) cellWidth = cellWidth * ((xDistance / cellSize) / columns);\n\n // rows | height | y\n var yFraction = cellSize / yDistance;\n var cellHeight = yFraction * (north - south);\n if (completelyWithin === true) cellHeight = cellHeight * ((yDistance / cellSize) / rows);\n\n // iterate over columns & rows\n var currentX = west;\n for (var column = 0; column < columns; column++) {\n var currentY = south;\n for (var row = 0; row < rows; row++) {\n var cellPoly = polygon([[\n [currentX, currentY],\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY]\n ]]);\n results.push(cellPoly);\n\n currentY += cellHeight;\n }\n currentX += cellWidth;\n }\n return featureCollection(results);\n};\n","var distance = require('@turf/distance');\nvar helpers = require('@turf/helpers');\nvar polygon = helpers.polygon;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a bounding box and a cell depth and returns a set of triangular {@link Polygon|polygons} in a grid.\n *\n * @name triangleGrid\n * @param {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @param {number} cellSize dimension of each cell\n * @param {string} [units=kilometers] used in calculating cellSize, can be degrees, radians, miles, or kilometers\n * @returns {FeatureCollection} grid of polygons\n * @example\n * var bbox = [-95, 30 ,-85, 40];\n * var cellSize = 50;\n * var units = 'miles';\n *\n * var triangleGrid = turf.triangleGrid(bbox, cellSize, units);\n *\n * //addToMap\n * var addToMap = [triangleGrid];\n */\nmodule.exports = function (bbox, cellSize, units) {\n var fc = featureCollection([]);\n var xFraction = cellSize / (distance([bbox[0], bbox[1]], [bbox[2], bbox[1]], units));\n var cellWidth = xFraction * (bbox[2] - bbox[0]);\n var yFraction = cellSize / (distance([bbox[0], bbox[1]], [bbox[0], bbox[3]], units));\n var cellHeight = yFraction * (bbox[3] - bbox[1]);\n\n var xi = 0;\n var currentX = bbox[0];\n while (currentX <= bbox[2]) {\n var yi = 0;\n var currentY = bbox[1];\n while (currentY <= bbox[3]) {\n if (xi % 2 === 0 && yi % 2 === 0) {\n fc.features.push(polygon([[\n [currentX, currentY],\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY]\n ]]), polygon([[\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY + cellHeight]\n ]]));\n } else if (xi % 2 === 0 && yi % 2 === 1) {\n fc.features.push(polygon([[\n [currentX, currentY],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY]\n ]]), polygon([[\n [currentX, currentY],\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX, currentY]\n ]]));\n } else if (yi % 2 === 0 && xi % 2 === 1) {\n fc.features.push(polygon([[\n [currentX, currentY],\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX, currentY]\n ]]), polygon([[\n [currentX, currentY],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY]\n ]]));\n } else if (yi % 2 === 1 && xi % 2 === 1) {\n fc.features.push(polygon([[\n [currentX, currentY],\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY]\n ]]), polygon([[\n [currentX, currentY + cellHeight],\n [currentX + cellWidth, currentY + cellHeight],\n [currentX + cellWidth, currentY],\n [currentX, currentY + cellHeight]\n ]]));\n }\n currentY += cellHeight;\n yi++;\n }\n xi++;\n currentX += cellWidth;\n }\n return fc;\n};\n\n","// depend on jsts for now http://bjornharrtell.github.io/jsts/\nvar jsts = require('jsts');\nvar truncate = require('@turf/truncate');\nvar feature = require('@turf/helpers').feature;\n\n/**\n * Takes two {@link Polygon|polygons} and finds their intersection. If they share a border, returns the border; if they don't intersect, returns undefined.\n *\n * @name intersect\n * @param {Feature} poly1 the first polygon\n * @param {Feature} poly2 the second polygon\n * @returns {Feature|null} returns a feature representing the point(s) they share (in case of a {@link Point} or {@link MultiPoint}), the borders they share (in case of a {@link LineString} or a {@link MultiLineString}), the area they share (in case of {@link Polygon} or {@link MultiPolygon}). If they do not share any point, returns `null`.\n * @example\n * var poly1 = turf.polygon([[\n * [-122.801742, 45.48565],\n * [-122.801742, 45.60491],\n * [-122.584762, 45.60491],\n * [-122.584762, 45.48565],\n * [-122.801742, 45.48565]\n * ]]);\n *\n * var poly2 = turf.polygon([[\n * [-122.520217, 45.535693],\n * [-122.64038, 45.553967],\n * [-122.720031, 45.526554],\n * [-122.669906, 45.507309],\n * [-122.723464, 45.446643],\n * [-122.532577, 45.408574],\n * [-122.487258, 45.477466],\n * [-122.520217, 45.535693]\n * ]]);\n *\n * var intersection = turf.intersect(poly1, poly2);\n *\n * //addToMap\n * var addToMap = [poly1, poly2, intersection];\n */\nmodule.exports = function (poly1, poly2) {\n var geom1 = (poly1.type === 'Feature') ? poly1.geometry : poly1;\n var geom2 = (poly2.type === 'Feature') ? poly2.geometry : poly2;\n\n var reader = new jsts.io.GeoJSONReader();\n var a = reader.read(truncate(geom1));\n var b = reader.read(truncate(geom2));\n var intersection = a.intersection(b);\n\n // https://github.com/Turfjs/turf/issues/951\n if (intersection.isEmpty()) return null;\n\n var writer = new jsts.io.GeoJSONWriter();\n var geom = writer.write(intersection);\n return feature(geom);\n};\n","/**\n * GeoJSON BBox\n *\n * @private\n * @typedef {[number, number, number, number]} BBox\n */\n\n/**\n * GeoJSON Id\n *\n * @private\n * @typedef {(number|string)} Id\n */\n\n/**\n * GeoJSON FeatureCollection\n *\n * @private\n * @typedef {Object} FeatureCollection\n * @property {string} type\n * @property {?Id} id\n * @property {?BBox} bbox\n * @property {Feature[]} features\n */\n\n/**\n * GeoJSON Feature\n *\n * @private\n * @typedef {Object} Feature\n * @property {string} type\n * @property {?Id} id\n * @property {?BBox} bbox\n * @property {*} properties\n * @property {Geometry} geometry\n */\n\n/**\n * GeoJSON Geometry\n *\n * @private\n * @typedef {Object} Geometry\n * @property {string} type\n * @property {any[]} coordinates\n */\n\n/**\n * Callback for coordEach\n *\n * @callback coordEachCallback\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * Starts at index 0.\n * @param {number} featureIndex The current index of the feature being processed.\n * @param {number} featureSubIndex The current subIndex of the feature being processed.\n */\n\n/**\n * Iterate over coordinates in any GeoJSON object, similar to Array.forEach()\n *\n * @name coordEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentCoord, coordIndex, featureIndex, featureSubIndex)\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordEach(features, function (currentCoord, coordIndex, featureIndex, featureSubIndex) {\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=featureSubIndex\n * });\n */\nexport function coordEach(geojson, callback, excludeWrapCoord) {\n // Handles null Geometry -- Skips this GeoJSON\n if (geojson === null) return;\n var featureIndex, geometryIndex, j, k, l, geometry, stopG, coords,\n geometryMaybeCollection,\n wrapShrink = 0,\n coordIndex = 0,\n isGeometryCollection,\n type = geojson.type,\n isFeatureCollection = type === 'FeatureCollection',\n isFeature = type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (featureIndex = 0; featureIndex < stop; featureIndex++) {\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[featureIndex].geometry :\n (isFeature ? geojson.geometry : geojson));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (geometryIndex = 0; geometryIndex < stopG; geometryIndex++) {\n var featureSubIndex = 0;\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[geometryIndex] : geometryMaybeCollection;\n\n // Handles null Geometry -- Skips this geometry\n if (geometry === null) continue;\n coords = geometry.coordinates;\n var geomType = geometry.type;\n\n wrapShrink = (excludeWrapCoord && (geomType === 'Polygon' || geomType === 'MultiPolygon')) ? 1 : 0;\n\n switch (geomType) {\n case null:\n break;\n case 'Point':\n callback(coords, coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n featureSubIndex++;\n break;\n case 'LineString':\n case 'MultiPoint':\n for (j = 0; j < coords.length; j++) {\n callback(coords[j], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n if (geomType === 'MultiPoint') featureSubIndex++;\n }\n if (geomType === 'LineString') featureSubIndex++;\n break;\n case 'Polygon':\n case 'MultiLineString':\n for (j = 0; j < coords.length; j++) {\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n callback(coords[j][k], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n }\n if (geomType === 'MultiLineString') featureSubIndex++;\n }\n if (geomType === 'Polygon') featureSubIndex++;\n break;\n case 'MultiPolygon':\n for (j = 0; j < coords.length; j++) {\n for (k = 0; k < coords[j].length; k++)\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n callback(coords[j][k][l], coordIndex, featureIndex, featureSubIndex);\n coordIndex++;\n }\n featureSubIndex++;\n }\n break;\n case 'GeometryCollection':\n for (j = 0; j < geometry.geometries.length; j++)\n coordEach(geometry.geometries[j], callback, excludeWrapCoord);\n break;\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n }\n}\n\n/**\n * Callback for coordReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback coordReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Array} currentCoord The current coordinate being processed.\n * @param {number} coordIndex The current index of the coordinate being processed.\n * Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureIndex The current index of the feature being processed.\n * @param {number} featureSubIndex The current subIndex of the feature being processed.\n */\n\n/**\n * Reduce coordinates in any GeoJSON object, similar to Array.reduce()\n *\n * @name coordReduce\n * @param {FeatureCollection|Geometry|Feature} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentCoord, coordIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.coordReduce(features, function (previousValue, currentCoord, coordIndex, featureIndex, featureSubIndex) {\n * //=previousValue\n * //=currentCoord\n * //=coordIndex\n * //=featureIndex\n * //=featureSubIndex\n * return currentCoord;\n * });\n */\nexport function coordReduce(geojson, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(geojson, function (currentCoord, coordIndex, featureIndex, featureSubIndex) {\n if (coordIndex === 0 && initialValue === undefined) previousValue = currentCoord;\n else previousValue = callback(previousValue, currentCoord, coordIndex, featureIndex, featureSubIndex);\n }, excludeWrapCoord);\n return previousValue;\n}\n\n/**\n * Callback for propEach\n *\n * @callback propEachCallback\n * @param {Object} currentProperties The current properties being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over properties in any GeoJSON object, similar to Array.forEach()\n *\n * @name propEach\n * @param {(FeatureCollection|Feature)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentProperties, featureIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propEach(features, function (currentProperties, featureIndex) {\n * //=currentProperties\n * //=featureIndex\n * });\n */\nexport function propEach(geojson, callback) {\n var i;\n switch (geojson.type) {\n case 'FeatureCollection':\n for (i = 0; i < geojson.features.length; i++) {\n callback(geojson.features[i].properties, i);\n }\n break;\n case 'Feature':\n callback(geojson.properties, 0);\n break;\n }\n}\n\n\n/**\n * Callback for propReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback propReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {*} currentProperties The current properties being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce properties in any GeoJSON object into a single value,\n * similar to how Array.reduce works. However, in this case we lazily run\n * the reduction, so an array of all properties is unnecessary.\n *\n * @name propReduce\n * @param {(FeatureCollection|Feature)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentProperties, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.propReduce(features, function (previousValue, currentProperties, featureIndex) {\n * //=previousValue\n * //=currentProperties\n * //=featureIndex\n * return currentProperties\n * });\n */\nexport function propReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n propEach(geojson, function (currentProperties, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentProperties;\n else previousValue = callback(previousValue, currentProperties, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for featureEach\n *\n * @callback featureEachCallback\n * @param {Feature} currentFeature The current feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Iterate over features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name featureEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.featureEach(features, function (currentFeature, featureIndex) {\n * //=currentFeature\n * //=featureIndex\n * });\n */\nexport function featureEach(geojson, callback) {\n if (geojson.type === 'Feature') {\n callback(geojson, 0);\n } else if (geojson.type === 'FeatureCollection') {\n for (var i = 0; i < geojson.features.length; i++) {\n callback(geojson.features[i], i);\n }\n }\n}\n\n/**\n * Callback for featureReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback featureReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name featureReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {\"foo\": \"bar\"}),\n * turf.point([36, 53], {\"hello\": \"world\"})\n * ]);\n *\n * turf.featureReduce(features, function (previousValue, currentFeature, featureIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * return currentFeature\n * });\n */\nexport function featureReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(geojson, function (currentFeature, featureIndex) {\n if (featureIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex);\n });\n return previousValue;\n}\n\n/**\n * Get all coordinates from any GeoJSON object.\n *\n * @name coordAll\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @returns {Array>} coordinate position array\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * var coords = turf.coordAll(features);\n * //= [[26, 37], [36, 53]]\n */\nexport function coordAll(geojson) {\n var coords = [];\n coordEach(geojson, function (coord) {\n coords.push(coord);\n });\n return coords;\n}\n\n/**\n * Callback for geomEach\n *\n * @callback geomEachCallback\n * @param {Geometry} currentGeometry The current geometry being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} currentProperties The current feature properties being processed.\n */\n\n/**\n * Iterate over each geometry in any GeoJSON object, similar to Array.forEach()\n *\n * @name geomEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentGeometry, featureIndex, currentProperties)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomEach(features, function (currentGeometry, featureIndex, currentProperties) {\n * //=currentGeometry\n * //=featureIndex\n * //=currentProperties\n * });\n */\nexport function geomEach(geojson, callback) {\n var i, j, g, geometry, stopG,\n geometryMaybeCollection,\n isGeometryCollection,\n geometryProperties,\n featureIndex = 0,\n isFeatureCollection = geojson.type === 'FeatureCollection',\n isFeature = geojson.type === 'Feature',\n stop = isFeatureCollection ? geojson.features.length : 1;\n\n // This logic may look a little weird. The reason why it is that way\n // is because it's trying to be fast. GeoJSON supports multiple kinds\n // of objects at its root: FeatureCollection, Features, Geometries.\n // This function has the responsibility of handling all of them, and that\n // means that some of the `for` loops you see below actually just don't apply\n // to certain inputs. For instance, if you give this just a\n // Point geometry, then both loops are short-circuited and all we do\n // is gradually rename the input until it's called 'geometry'.\n //\n // This also aims to allocate as few resources as possible: just a\n // few numbers and booleans, rather than any temporary arrays as would\n // be required with the normalization approach.\n for (i = 0; i < stop; i++) {\n\n geometryMaybeCollection = (isFeatureCollection ? geojson.features[i].geometry :\n (isFeature ? geojson.geometry : geojson));\n geometryProperties = (isFeatureCollection ? geojson.features[i].properties :\n (isFeature ? geojson.properties : {}));\n isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ?\n geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n\n // Handle null Geometry\n if (geometry === null) {\n callback(null, featureIndex, geometryProperties);\n continue;\n }\n switch (geometry.type) {\n case 'Point':\n case 'LineString':\n case 'MultiPoint':\n case 'Polygon':\n case 'MultiLineString':\n case 'MultiPolygon': {\n callback(geometry, featureIndex, geometryProperties);\n break;\n }\n case 'GeometryCollection': {\n for (j = 0; j < geometry.geometries.length; j++) {\n callback(geometry.geometries[j], featureIndex, geometryProperties);\n }\n break;\n }\n default:\n throw new Error('Unknown Geometry Type');\n }\n }\n // Only increase `featureIndex` per each feature\n featureIndex++;\n }\n}\n\n/**\n * Callback for geomReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback geomReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Geometry} currentGeometry The current Feature being processed.\n * @param {number} currentIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {Object} currentProperties The current feature properties being processed.\n */\n\n/**\n * Reduce geometry in any GeoJSON object, similar to Array.reduce().\n *\n * @name geomReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentGeometry, featureIndex, currentProperties)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.point([36, 53], {hello: 'world'})\n * ]);\n *\n * turf.geomReduce(features, function (previousValue, currentGeometry, featureIndex, currentProperties) {\n * //=previousValue\n * //=currentGeometry\n * //=featureIndex\n * //=currentProperties\n * return currentGeometry\n * });\n */\nexport function geomReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(geojson, function (currentGeometry, currentIndex, currentProperties) {\n if (currentIndex === 0 && initialValue === undefined) previousValue = currentGeometry;\n else previousValue = callback(previousValue, currentGeometry, currentIndex, currentProperties);\n });\n return previousValue;\n}\n\n/**\n * Callback for flattenEach\n *\n * @callback flattenEachCallback\n * @param {Feature} currentFeature The current flattened feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureSubIndex The subindex of the current element being processed in the\n * array. Starts at index 0 and increases if the flattened feature was a multi-geometry.\n */\n\n/**\n * Iterate over flattened features in any GeoJSON object, similar to\n * Array.forEach.\n *\n * @name flattenEach\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (currentFeature, featureIndex, featureSubIndex)\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenEach(features, function (currentFeature, featureIndex, featureSubIndex) {\n * //=currentFeature\n * //=featureIndex\n * //=featureSubIndex\n * });\n */\nexport function flattenEach(geojson, callback) {\n geomEach(geojson, function (geometry, featureIndex, properties) {\n // Callback for single geometry\n var type = (geometry === null) ? null : geometry.type;\n switch (type) {\n case null:\n case 'Point':\n case 'LineString':\n case 'Polygon':\n callback(feature(geometry, properties), featureIndex, 0);\n return;\n }\n\n var geomType;\n\n // Callback for multi-geometry\n switch (type) {\n case 'MultiPoint':\n geomType = 'Point';\n break;\n case 'MultiLineString':\n geomType = 'LineString';\n break;\n case 'MultiPolygon':\n geomType = 'Polygon';\n break;\n }\n\n geometry.coordinates.forEach(function (coordinate, featureSubIndex) {\n var geom = {\n type: geomType,\n coordinates: coordinate\n };\n callback(feature(geom, properties), featureIndex, featureSubIndex);\n });\n\n });\n}\n\n/**\n * Callback for flattenReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback flattenReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentFeature The current Feature being processed.\n * @param {number} featureIndex The index of the current element being processed in the\n * array.Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} featureSubIndex The subindex of the current element being processed in the\n * array. Starts at index 0 and increases if the flattened feature was a multi-geometry.\n */\n\n/**\n * Reduce flattened features in any GeoJSON object, similar to Array.reduce().\n *\n * @name flattenReduce\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex, featureSubIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var features = turf.featureCollection([\n * turf.point([26, 37], {foo: 'bar'}),\n * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'})\n * ]);\n *\n * turf.flattenReduce(features, function (previousValue, currentFeature, featureIndex, featureSubIndex) {\n * //=previousValue\n * //=currentFeature\n * //=featureIndex\n * //=featureSubIndex\n * return currentFeature\n * });\n */\nexport function flattenReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n flattenEach(geojson, function (currentFeature, featureIndex, featureSubIndex) {\n if (featureIndex === 0 && featureSubIndex === 0 && initialValue === undefined) previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex, featureSubIndex);\n });\n return previousValue;\n}\n\n/**\n * Callback for segmentEach\n *\n * @callback segmentEachCallback\n * @param {Feature} currentSegment The current segment being processed.\n * @param {number} featureIndex The featureIndex currently being processed, starts at index 0.\n * @param {number} featureSubIndex The featureSubIndex currently being processed, starts at index 0.\n * @param {number} segmentIndex The segmentIndex currently being processed, starts at index 0.\n * @returns {void}\n */\n\n/**\n * Iterate over 2-vertex line segment in any GeoJSON object, similar to Array.forEach()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON\n * @param {Function} callback a method that takes (currentSegment, featureIndex, featureSubIndex)\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentEach(polygon, function (currentSegment, featureIndex, featureSubIndex, segmentIndex) {\n * //= currentSegment\n * //= featureIndex\n * //= featureSubIndex\n * //= segmentIndex\n * });\n *\n * // Calculate the total number of segments\n * var total = 0;\n * turf.segmentEach(polygon, function () {\n * total++;\n * });\n */\nexport function segmentEach(geojson, callback) {\n flattenEach(geojson, function (feature, featureIndex, featureSubIndex) {\n var segmentIndex = 0;\n\n // Exclude null Geometries\n if (!feature.geometry) return;\n // (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n var type = feature.geometry.type;\n if (type === 'Point' || type === 'MultiPoint') return;\n\n // Generate 2-vertex line segments\n coordReduce(feature, function (previousCoords, currentCoord) {\n var currentSegment = lineString([previousCoords, currentCoord], feature.properties);\n callback(currentSegment, featureIndex, featureSubIndex, segmentIndex);\n segmentIndex++;\n return currentCoord;\n });\n });\n}\n\n/**\n * Callback for segmentReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback segmentReduceCallback\n * @param {*} [previousValue] The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} [currentSegment] The current segment being processed.\n * @param {number} featureIndex The featureIndex currently being processed, starts at index 0.\n * @param {number} featureSubIndex The featureSubIndex currently being processed, starts at index 0.\n * @param {number} segmentIndex The segmentIndex currently being processed, starts at index 0.\n */\n\n/**\n * Reduce 2-vertex line segment in any GeoJSON object, similar to Array.reduce()\n * (Multi)Point geometries do not contain segments therefore they are ignored during this operation.\n *\n * @param {(FeatureCollection|Feature|Geometry)} geojson any GeoJSON\n * @param {Function} callback a method that takes (previousValue, currentSegment, currentIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {void}\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n *\n * // Iterate over GeoJSON by 2-vertex segments\n * turf.segmentReduce(polygon, function (previousSegment, currentSegment, featureIndex, featureSubIndex, segmentIndex) {\n * //= previousSegment\n * //= currentSegment\n * //= featureIndex\n * //= featureSubIndex\n * //= segmentInex\n * return currentSegment\n * });\n *\n * // Calculate the total number of segments\n * var initialValue = 0\n * var total = turf.segmentReduce(polygon, function (previousValue) {\n * previousValue++;\n * return previousValue;\n * }, initialValue);\n */\nexport function segmentReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n var started = false;\n segmentEach(geojson, function (currentSegment, featureIndex, featureSubIndex, segmentIndex) {\n if (started === false && initialValue === undefined) previousValue = currentSegment;\n else previousValue = callback(previousValue, currentSegment, featureIndex, featureSubIndex, segmentIndex);\n started = true;\n });\n return previousValue;\n}\n\n/**\n * Create Feature\n *\n * @private\n * @param {Geometry} geometry GeoJSON Geometry\n * @param {Object} properties Properties\n * @returns {Feature} GeoJSON Feature\n */\nexport function feature(geometry, properties) {\n if (geometry === undefined) throw new Error('No geometry passed');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: geometry\n };\n}\n\n/**\n * Create LineString\n *\n * @private\n * @param {Array>} coordinates Line Coordinates\n * @param {Object} properties Properties\n * @returns {Feature} GeoJSON LineString Feature\n */\nexport function lineString(coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length < 2) throw new Error('Coordinates must be an array of two or more positions');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: {\n type: 'LineString',\n coordinates: coordinates\n }\n };\n}\n\n\n/**\n * Callback for lineEach\n *\n * @callback lineEachCallback\n * @param {Feature} currentLine The current LineString|LinearRing being processed.\n * @param {number} lineIndex The index of the current element being processed in the array, starts at index 0.\n * @param {number} lineSubIndex The sub-index of the current line being processed at index 0\n */\n\n/**\n * Iterate over line or ring coordinates in LineString, Polygon, MultiLineString, MultiPolygon Features or Geometries,\n * similar to Array.forEach.\n *\n * @name lineEach\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (currentLine, lineIndex, lineSubIndex)\n * @example\n * var mtLn = turf.multiLineString([\n * turf.lineString([[26, 37], [35, 45]]),\n * turf.lineString([[36, 53], [38, 50], [41, 55]])\n * ]);\n *\n * turf.lineEach(mtLn, function (currentLine, lineIndex) {\n * //=currentLine\n * //=lineIndex\n * });\n */\nexport function lineEach(geojson, callback) {\n // validation\n if (!geojson) throw new Error('geojson is required');\n var type = geojson.geometry ? geojson.geometry.type : geojson.type;\n if (!type) throw new Error('invalid geojson');\n if (type === 'FeatureCollection') throw new Error('FeatureCollection is not supported');\n if (type === 'GeometryCollection') throw new Error('GeometryCollection is not supported');\n var coordinates = geojson.geometry ? geojson.geometry.coordinates : geojson.coordinates;\n if (!coordinates) throw new Error('geojson must contain coordinates');\n\n switch (type) {\n case 'LineString':\n callback(coordinates, 0, 0);\n return;\n case 'Polygon':\n case 'MultiLineString':\n var subIndex = 0;\n for (var line = 0; line < coordinates.length; line++) {\n if (type === 'MultiLineString') subIndex = line;\n callback(coordinates[line], line, subIndex);\n }\n return;\n case 'MultiPolygon':\n for (var multi = 0; multi < coordinates.length; multi++) {\n for (var ring = 0; ring < coordinates[multi].length; ring++) {\n callback(coordinates[multi][ring], ring, multi);\n }\n }\n return;\n default:\n throw new Error(type + ' geometry not supported');\n }\n}\n\n/**\n * Callback for lineReduce\n *\n * The first time the callback function is called, the values provided as arguments depend\n * on whether the reduce method has an initialValue argument.\n *\n * If an initialValue is provided to the reduce method:\n * - The previousValue argument is initialValue.\n * - The currentValue argument is the value of the first element present in the array.\n *\n * If an initialValue is not provided:\n * - The previousValue argument is the value of the first element present in the array.\n * - The currentValue argument is the value of the second element present in the array.\n *\n * @callback lineReduceCallback\n * @param {*} previousValue The accumulated value previously returned in the last invocation\n * of the callback, or initialValue, if supplied.\n * @param {Feature} currentLine The current LineString|LinearRing being processed.\n * @param {number} lineIndex The index of the current element being processed in the\n * array. Starts at index 0, if an initialValue is provided, and at index 1 otherwise.\n * @param {number} lineSubIndex The sub-index of the current line being processed at index 0\n */\n\n/**\n * Reduce features in any GeoJSON object, similar to Array.reduce().\n *\n * @name lineReduce\n * @param {Geometry|Feature} geojson object\n * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex)\n * @param {*} [initialValue] Value to use as the first argument to the first call of the callback.\n * @returns {*} The value that results from the reduction.\n * @example\n * var mtp = turf.multiPolygon([\n * turf.polygon([[[12,48],[2,41],[24,38],[12,48]], [[9,44],[13,41],[13,45],[9,44]]]),\n * turf.polygon([[[5, 5], [0, 0], [2, 2], [4, 4], [5, 5]]])\n * ]);\n *\n * turf.lineReduce(mtp, function (previousValue, currentLine, lineIndex, lineSubIndex) {\n * //=previousValue\n * //=currentLine\n * //=lineIndex\n * //=lineSubIndex\n * return currentLine\n * }, 2);\n */\nexport function lineReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n lineEach(geojson, function (currentLine, lineIndex, lineSubIndex) {\n if (lineIndex === 0 && initialValue === undefined) previousValue = currentLine;\n else previousValue = callback(previousValue, currentLine, lineIndex, lineSubIndex);\n });\n return previousValue;\n}\n","var bearing = require('@turf/bearing');\nvar destination = require('@turf/destination');\nvar distance = require('@turf/distance');\n\n/**\n * Takes two {@link Point|points} and returns a point midway between them.\n * The midpoint is calculated geodesically, meaning the curvature of the earth is taken into account.\n *\n * @name midpoint\n * @param {Geometry|Feature|Array} point1 first point\n * @param {Geometry|Feature|Array} point2 second point\n * @returns {Feature} a point midway between `pt1` and `pt2`\n * @example\n * var point1 = turf.point([144.834823, -37.771257]);\n * var point2 = turf.point([145.14244, -37.830937]);\n *\n * var midpoint = turf.midpoint(point1, point2);\n *\n * //addToMap\n * var addToMap = [point1, point2, midpoint];\n * midpoint.properties['marker-color'] = '#f00';\n */\nmodule.exports = function (point1, point2) {\n var dist = distance(point1, point2, 'miles');\n var heading = bearing(point1, point2);\n var midpoint = destination(point1, dist / 2, heading, 'miles');\n\n return midpoint;\n};\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ZoneMapCreation.vue?vue&type=style&index=0&id=1887498b&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ZoneMapCreation.vue?vue&type=style&index=0&id=1887498b&lang=scss&scoped=true&\"","var getCoords = require('@turf/invariant').getCoords;\nvar helpers = require('@turf/helpers');\nvar lineString = helpers.lineString;\nvar multiLineString = helpers.multiLineString;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Converts a {@link Polygon} to {@link LineString|(Multi)LineString} or {@link MultiPolygon} to a {@link FeatureCollection} of {@link LineString|(Multi)LineString}.\n *\n * @name polygonToLineString\n * @param {Feature} polygon Feature to convert\n * @param {Object} [properties] translates GeoJSON properties to Feature\n * @returns {FeatureCollection|Feature} converted (Multi)Polygon to (Multi)LineString\n * @example\n * var poly = turf.polygon([[[125, -30], [145, -30], [145, -20], [125, -20], [125, -30]]]);\n *\n * var line = turf.polygonToLineString(poly);\n *\n * //addToMap\n * var addToMap = [line];\n */\nmodule.exports = function (polygon, properties) {\n var geom = getGeomType(polygon);\n var coords = getCoords(polygon);\n properties = properties || polygon.properties || {};\n\n if (!coords.length) throw new Error('polygon must contain coordinates');\n\n switch (geom) {\n case 'Polygon':\n return coordsToLine(coords, properties);\n case 'MultiPolygon':\n var lines = [];\n coords.forEach(function (coord) {\n lines.push(coordsToLine(coord, properties));\n });\n return featureCollection(lines);\n default:\n throw new Error('geom ' + geom + ' not supported');\n }\n};\n\nfunction coordsToLine(coords, properties) {\n if (coords.length > 1) return multiLineString(coords, properties);\n return lineString(coords[0], properties);\n}\n\nfunction getGeomType(feature) {\n return (feature.geometry) ? feature.geometry.type : feature.type;\n}\n","'use strict'\n\nmodule.exports = affineHull\n\nvar orient = require('robust-orientation')\n\nfunction linearlyIndependent(points, d) {\n var nhull = new Array(d+1)\n for(var i=0; i 0 && typeof x[0] !== 'number') return false;\n return true;\n}\n\nfunction objEquiv(a, b, opts) {\n var i, key;\n if (isUndefinedOrNull(a) || isUndefinedOrNull(b))\n return false;\n // an identical 'prototype' property.\n if (a.prototype !== b.prototype) return false;\n //~~~I've managed to break Object.keys through screwy arguments passing.\n // Converting to array solves the problem.\n if (isArguments(a)) {\n if (!isArguments(b)) {\n return false;\n }\n a = pSlice.call(a);\n b = pSlice.call(b);\n return deepEqual(a, b, opts);\n }\n if (isBuffer(a)) {\n if (!isBuffer(b)) {\n return false;\n }\n if (a.length !== b.length) return false;\n for (i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n }\n try {\n var ka = objectKeys(a),\n kb = objectKeys(b);\n } catch (e) {//happens when one is a string literal and the other isn't\n return false;\n }\n // having the same number of owned properties (keys incorporates\n // hasOwnProperty)\n if (ka.length != kb.length)\n return false;\n //the same set of keys (although not necessarily the same order),\n ka.sort();\n kb.sort();\n //~~~cheap key test\n for (i = ka.length - 1; i >= 0; i--) {\n if (ka[i] != kb[i])\n return false;\n }\n //equivalent values for every corresponding key, and\n //~~~possibly expensive deep test\n for (i = ka.length - 1; i >= 0; i--) {\n key = ka[i];\n if (!deepEqual(a[key], b[key], opts)) return false;\n }\n return typeof a === typeof b;\n}\n","var linestring = require('@turf/helpers').lineString;\nvar pointOnLine = require('@turf/point-on-line');\n\n/**\n * Takes a {@link LineString|line}, a start {@link Point}, and a stop point\n * and returns a subsection of the line in-between those points.\n * The start & stop points don't need to fall exactly on the line.\n *\n * This can be useful for extracting only the part of a route between waypoints.\n *\n * @name lineSlice\n * @param {Feature} startPt starting point\n * @param {Feature} stopPt stopping point\n * @param {Feature|LineString} line line to slice\n * @returns {Feature} sliced line\n * @example\n * var line = turf.lineString([\n * [-77.031669, 38.878605],\n * [-77.029609, 38.881946],\n * [-77.020339, 38.884084],\n * [-77.025661, 38.885821],\n * [-77.021884, 38.889563],\n * [-77.019824, 38.892368]\n * ]);\n * var start = turf.point([-77.029609, 38.881946]);\n * var stop = turf.point([-77.021884, 38.889563]);\n *\n * var sliced = turf.lineSlice(start, stop, line);\n *\n * //addToMap\n * var addToMap = [start, stop, line]\n */\nmodule.exports = function lineSlice(startPt, stopPt, line) {\n var coords;\n if (line.type === 'Feature') {\n coords = line.geometry.coordinates;\n } else if (line.type === 'LineString') {\n coords = line.coordinates;\n } else {\n throw new Error('input must be a LineString Feature or Geometry');\n }\n\n var startVertex = pointOnLine(line, startPt);\n var stopVertex = pointOnLine(line, stopPt);\n var ends;\n if (startVertex.properties.index <= stopVertex.properties.index) {\n ends = [startVertex, stopVertex];\n } else {\n ends = [stopVertex, startVertex];\n }\n var clipCoords = [ends[0].geometry.coordinates];\n for (var i = ends[0].properties.index + 1; i < ends[1].properties.index + 1; i++) {\n clipCoords.push(coords[i]);\n }\n clipCoords.push(ends[1].geometry.coordinates);\n return linestring(clipCoords, line.properties);\n};\n","\r\n\r\n\r\n\r\n\r\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./IxWmsLayer.vue?vue&type=style&index=0&id=41702c76&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./IxWmsLayer.vue?vue&type=style&index=0&id=41702c76&lang=scss&scoped=true&\"","var turfUnion = require('@turf/union');\nvar booleanOverlap = require('@turf/boolean-overlap');\nvar turfbbox = require('@turf/bbox');\nvar Rbush = require('rbush');\nvar gju = require('geojson-utils');\nvar getClosest = require('get-closest');\n\n/**\n * Dissolves a FeatureCollection of polygons based on a property. Note that multipart features within the collection are not supported\n *\n * @name dissolve\n * @param {FeatureCollection} featureCollection input feature collection to be dissolved\n * @param {string} [propertyName] property name on which to dissolve features\n * @returns {FeatureCollection} a FeatureCollection containing the dissolved polygons\n * @example\n * var features = turf.featureCollection([\n * turf.polygon([[[0, 0], [0, 1], [1, 1], [1, 0], [0, 0]]], {\"combine\": \"yes\"}),\n * turf.polygon([[[0, -1], [0, 0], [1, 0], [1, -1], [0,-1]]], {\"combine\": \"yes\"}),\n * turf.polygon([[[1,-1],[1, 0], [2, 0], [2, -1], [1, -1]]], {\"combine\": \"no\"}),\n * ]);\n *\n * var dissolved = turf.dissolve(features, 'combine');\n *\n * //addToMap\n * var addToMap = [features, dissolved]\n */\nmodule.exports = function (featureCollection, propertyName) {\n\n var originalIndexOfItemsRemoved = [];\n var treeItems = [];\n var rtree = new Rbush();\n for (var polyIndex = 0; polyIndex < featureCollection.features.length; polyIndex++) {\n var inputFeatureBbox = turfbbox(featureCollection.features[polyIndex]);\n var treeObj = {\n minX: inputFeatureBbox[0],\n minY: inputFeatureBbox[1],\n maxX: inputFeatureBbox[2],\n maxY: inputFeatureBbox[3],\n origIndexPosition: polyIndex\n };\n treeItems.push(treeObj);\n }\n rtree.load(treeItems);\n\n for (var i = 0; i < featureCollection.features.length; i++) {\n var polygon = featureCollection.features[i];\n\n var polyBoundingBox = turfbbox(polygon);\n var searchObj = {\n minX: polyBoundingBox[0],\n minY: polyBoundingBox[1],\n maxX: polyBoundingBox[2],\n maxY: polyBoundingBox[3]\n };\n var potentialMatchingFeatures = rtree.search(searchObj);\n\n var featureChanged = false;\n\n for (var searchIndex = 0; searchIndex < potentialMatchingFeatures.length; searchIndex++) {\n polygon = featureCollection.features[i];\n\n var matchFeaturePosition = potentialMatchingFeatures[searchIndex].origIndexPosition;\n\n if (originalIndexOfItemsRemoved.length > 0 && matchFeaturePosition !== 0) {\n if (matchFeaturePosition > originalIndexOfItemsRemoved[originalIndexOfItemsRemoved.length - 1]) {\n matchFeaturePosition = matchFeaturePosition - (originalIndexOfItemsRemoved.length);\n } else {\n var closestNumber = getClosest.greaterNumber(matchFeaturePosition, originalIndexOfItemsRemoved);\n if (closestNumber !== 0) {\n matchFeaturePosition = matchFeaturePosition - closestNumber;\n }\n }\n }\n\n if (matchFeaturePosition === i) {\n continue;\n }\n var matchFeature = featureCollection.features[matchFeaturePosition];\n\n if (typeof propertyName !== undefined) {\n if (matchFeature.properties[propertyName] !== polygon.properties[propertyName]) {\n continue;\n }\n }\n\n var overlapCheck = booleanOverlap(polygon, matchFeature);\n\n if (!overlapCheck) {\n var polyClone = JSON.stringify(polygon);\n var polyBeingCheckedClone = JSON.stringify(matchFeature);\n var linestring1 = toLinestring(JSON.parse(polyClone));\n var linestring2 = toLinestring(JSON.parse(polyBeingCheckedClone));\n overlapCheck = gju.lineStringsIntersect(linestring1.geometry, linestring2.geometry);\n }\n if (!overlapCheck) {\n continue;\n }\n\n featureCollection.features[i] = turfUnion(polygon, matchFeature);\n originalIndexOfItemsRemoved.push(potentialMatchingFeatures[searchIndex].origIndexPosition);\n originalIndexOfItemsRemoved.sort(function (a, b) {\n return a - b;\n });\n\n rtree.remove(potentialMatchingFeatures[searchIndex]);\n featureCollection.features.splice(matchFeaturePosition, 1);\n searchObj.origIndexPosition = i;\n rtree.remove(searchObj, function (a, b) {\n return a.origIndexPosition === b.origIndexPosition;\n });\n featureChanged = true;\n }\n if (featureChanged) {\n var newBoundingBox = turfbbox(polygon);\n rtree.insert({\n minX: newBoundingBox[0],\n minY: newBoundingBox[1],\n maxX: newBoundingBox[2],\n maxY: newBoundingBox[3],\n origIndexPosition: i\n });\n i--;\n }\n }\n return featureCollection;\n};\n\nfunction toLinestring(polygon) {\n if (polygon === null || polygon === undefined) throw new Error('No polygon was passed');\n polygon.geometry.type = 'LineString';\n var flat_arr = [].concat.apply([], polygon.geometry.coordinates);\n polygon.geometry.coordinates = flat_arr;\n return polygon;\n}\n","var invariant = require('@turf/invariant');\nvar getCoord = invariant.getCoord;\nvar getCoords = invariant.getCoords;\n\n// http://en.wikipedia.org/wiki/Even%E2%80%93odd_rule\n// modified from: https://github.com/substack/point-in-polygon/blob/master/index.js\n// which was modified from http://www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html\n\n/**\n * Takes a {@link Point} and a {@link Polygon} or {@link MultiPolygon} and determines if the point resides inside the polygon. The polygon can\n * be convex or concave. The function accounts for holes.\n *\n * @name inside\n * @param {Feature} point input point\n * @param {Feature} polygon input polygon or multipolygon\n * @param {boolean} [ignoreBoundary=false] True if polygon boundary should be ignored when determining if the point is inside the polygon otherwise false.\n * @returns {boolean} `true` if the Point is inside the Polygon; `false` if the Point is not inside the Polygon\n * @example\n * var pt = turf.point([-77, 44]);\n * var poly = turf.polygon([[\n * [-81, 41],\n * [-81, 47],\n * [-72, 47],\n * [-72, 41],\n * [-81, 41]\n * ]]);\n *\n * turf.inside(pt, poly);\n * //= true\n */\nmodule.exports = function (point, polygon, ignoreBoundary) {\n // validation\n if (!point) throw new Error('point is required');\n if (!polygon) throw new Error('polygon is required');\n\n var pt = getCoord(point);\n var polys = getCoords(polygon);\n var type = (polygon.geometry) ? polygon.geometry.type : polygon.type;\n var bbox = polygon.bbox;\n\n // Quick elimination if point is not inside bbox\n if (bbox && inBBox(pt, bbox) === false) return false;\n\n // normalize to multipolygon\n if (type === 'Polygon') polys = [polys];\n\n for (var i = 0, insidePoly = false; i < polys.length && !insidePoly; i++) {\n // check if it is in the outer ring first\n if (inRing(pt, polys[i][0], ignoreBoundary)) {\n var inHole = false;\n var k = 1;\n // check for the point in any of the holes\n while (k < polys[i].length && !inHole) {\n if (inRing(pt, polys[i][k], !ignoreBoundary)) {\n inHole = true;\n }\n k++;\n }\n if (!inHole) insidePoly = true;\n }\n }\n return insidePoly;\n};\n\n/**\n * inRing\n *\n * @private\n * @param {[number, number]} pt [x,y]\n * @param {Array<[number, number]>} ring [[x,y], [x,y],..]\n * @param {boolean} ignoreBoundary ignoreBoundary\n * @returns {boolean} inRing\n */\nfunction inRing(pt, ring, ignoreBoundary) {\n var isInside = false;\n if (ring[0][0] === ring[ring.length - 1][0] && ring[0][1] === ring[ring.length - 1][1]) ring = ring.slice(0, ring.length - 1);\n\n for (var i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n var xi = ring[i][0], yi = ring[i][1];\n var xj = ring[j][0], yj = ring[j][1];\n var onBoundary = (pt[1] * (xi - xj) + yi * (xj - pt[0]) + yj * (pt[0] - xi) === 0) &&\n ((xi - pt[0]) * (xj - pt[0]) <= 0) && ((yi - pt[1]) * (yj - pt[1]) <= 0);\n if (onBoundary) return !ignoreBoundary;\n var intersect = ((yi > pt[1]) !== (yj > pt[1])) &&\n (pt[0] < (xj - xi) * (pt[1] - yi) / (yj - yi) + xi);\n if (intersect) isInside = !isInside;\n }\n return isInside;\n}\n\n/**\n * inBBox\n *\n * @private\n * @param {[number, number]} pt point [x,y]\n * @param {[number, number, number, number]} bbox BBox [west, south, east, north]\n * @returns {boolean} true/false if point is inside BBox\n */\nfunction inBBox(pt, bbox) {\n return bbox[0] <= pt[0] &&\n bbox[1] <= pt[1] &&\n bbox[2] >= pt[0] &&\n bbox[3] >= pt[1];\n}\n","var bbox = require('@turf/bbox');\nvar bboxPolygon = require('@turf/bbox-polygon');\n\n/**\n * Takes any number of features and returns a rectangular {@link Polygon} that encompasses all vertices.\n *\n * @name envelope\n * @param {FeatureCollection|Feature} geojson input features\n * @returns {Feature} a rectangular Polygon feature that encompasses all vertices\n * @example\n * var features = turf.featureCollection([\n * turf.point([-75.343, 39.984], {\"name\": \"Location A\"}),\n * turf.point([-75.833, 39.284], {\"name\": \"Location B\"}),\n * turf.point([-75.534, 39.123], {\"name\": \"Location C\"})\n * ]);\n *\n * var enveloped = turf.envelope(features);\n *\n * //addToMap\n * var addToMap = [features, enveloped];\n */\nmodule.exports = function (geojson) {\n return bboxPolygon(bbox(geojson));\n};\n","var invariant = require('@turf/invariant');\n\n// http://en.wikipedia.org/wiki/Even%E2%80%93odd_rule\n// modified from: https://github.com/substack/point-in-polygon/blob/master/index.js\n// which was modified from http://www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html\n\n/**\n * Takes a {@link Point} and a {@link Polygon} or {@link MultiPolygon} and determines if the point resides inside the polygon. The polygon can\n * be convex or concave. The function accounts for holes.\n *\n * @name inside\n * @param {Feature} point input point\n * @param {Feature<(Polygon|MultiPolygon)>} polygon input polygon or multipolygon\n * @returns {boolean} `true` if the Point is inside the Polygon; `false` if the Point is not inside the Polygon\n * @example\n * var pt = turf.point([-77, 44]);\n * var poly = turf.polygon([[\n * [-81, 41],\n * [-81, 47],\n * [-72, 47],\n * [-72, 41],\n * [-81, 41]\n * ]]);\n *\n * var isInside = turf.inside(pt, poly);\n *\n * //=isInside\n */\nmodule.exports = function (point, polygon) {\n var pt = invariant.getCoord(point);\n var polys = polygon.geometry.coordinates;\n // normalize to multipolygon\n if (polygon.geometry.type === 'Polygon') polys = [polys];\n\n for (var i = 0, insidePoly = false; i < polys.length && !insidePoly; i++) {\n // check if it is in the outer ring first\n if (inRing(pt, polys[i][0])) {\n var inHole = false;\n var k = 1;\n // check for the point in any of the holes\n while (k < polys[i].length && !inHole) {\n if (inRing(pt, polys[i][k], true)) {\n inHole = true;\n }\n k++;\n }\n if (!inHole) insidePoly = true;\n }\n }\n return insidePoly;\n};\n\n// pt is [x,y] and ring is [[x,y], [x,y],..]\nfunction inRing(pt, ring, ignoreBoundary) {\n var isInside = false;\n if (ring[0][0] === ring[ring.length - 1][0] && ring[0][1] === ring[ring.length - 1][1]) ring = ring.slice(0, ring.length - 1);\n\n for (var i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n var xi = ring[i][0], yi = ring[i][1];\n var xj = ring[j][0], yj = ring[j][1];\n var onBoundary = (pt[1] * (xi - xj) + yi * (xj - pt[0]) + yj * (pt[0] - xi) === 0) &&\n ((xi - pt[0]) * (xj - pt[0]) <= 0) && ((yi - pt[1]) * (yj - pt[1]) <= 0);\n if (onBoundary) return !ignoreBoundary;\n var intersect = ((yi > pt[1]) !== (yj > pt[1])) &&\n (pt[0] < (xj - xi) * (pt[1] - yi) / (yj - yi) + xi);\n if (intersect) isInside = !isInside;\n }\n return isInside;\n}\n","var bearing = require('@turf/bearing');\nvar distance = require('@turf/distance');\nvar destination = require('@turf/destination');\nvar lineString = require('@turf/helpers').lineString;\n\n/**\n * Takes a {@link LineString|line}, a specified distance along the line to a start {@link Point},\n * and a specified distance along the line to a stop point\n * and returns a subsection of the line in-between those points.\n *\n * This can be useful for extracting only the part of a route between two distances.\n *\n * @name lineSliceAlong\n * @param {Feature|LineString} line input line\n * @param {number} startDist distance along the line to starting point\n * @param {number} stopDist distance along the line to ending point\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {Feature} sliced line\n * @example\n * var line = turf.lineString([[7, 45], [9, 45], [14, 40], [14, 41]]);\n * var start = 12.5;\n * var stop = 25;\n * var sliced = turf.lineSliceAlong(line, start, stop, 'miles');\n *\n * //addToMap\n * var addToMap = [line, start, stop, sliced]\n */\nmodule.exports = function (line, startDist, stopDist, units) {\n var coords;\n var slice = [];\n if (line.type === 'Feature') coords = line.geometry.coordinates;\n else if (line.type === 'LineString') coords = line.coordinates;\n else throw new Error('input must be a LineString Feature or Geometry');\n\n var travelled = 0;\n var overshot, direction, interpolated;\n for (var i = 0; i < coords.length; i++) {\n if (startDist >= travelled && i === coords.length - 1) break;\n else if (travelled > startDist && slice.length === 0) {\n overshot = startDist - travelled;\n if (!overshot) {\n slice.push(coords[i]);\n return lineString(slice);\n }\n direction = bearing(coords[i], coords[i - 1]) - 180;\n interpolated = destination(coords[i], overshot, direction, units);\n slice.push(interpolated.geometry.coordinates);\n }\n\n if (travelled >= stopDist) {\n overshot = stopDist - travelled;\n if (!overshot) {\n slice.push(coords[i]);\n return lineString(slice);\n }\n direction = bearing(coords[i], coords[i - 1]) - 180;\n interpolated = destination(coords[i], overshot, direction, units);\n slice.push(interpolated.geometry.coordinates);\n return lineString(slice);\n }\n\n if (travelled >= startDist) {\n slice.push(coords[i]);\n }\n\n if (i === coords.length - 1) {\n return lineString(slice);\n }\n\n travelled += distance(coords[i], coords[i + 1], units);\n }\n return lineString(coords[coords.length - 1]);\n};\n","var coordEach = require('@turf/meta').coordEach;\nvar point = require('@turf/helpers').point;\n\n/**\n * Takes one or more features and calculates the centroid using the mean of all vertices.\n * This lessens the effect of small islands and artifacts when calculating the centroid of a set of polygons.\n *\n * @name centroid\n * @param {GeoJSON} geojson GeoJSON to be centered\n * @param {Object} [properties] an Object that is used as the {@link Feature}'s properties\n * @returns {Feature} the centroid of the input features\n * @example\n * var polygon = turf.polygon([[[-81, 41], [-88, 36], [-84, 31], [-80, 33], [-77, 39], [-81, 41]]]);\n *\n * var centroid = turf.centroid(polygon);\n *\n * //addToMap\n * var addToMap = [polygon, centroid]\n */\nmodule.exports = function (geojson, properties) {\n var xSum = 0;\n var ySum = 0;\n var len = 0;\n coordEach(geojson, function (coord) {\n xSum += coord[0];\n ySum += coord[1];\n len++;\n }, true);\n return point([xSum / len, ySum / len], properties);\n};\n","/**\n * https://github.com/rook2pawn/node-intersection\n *\n * Author @rook2pawn\n */\n\n/**\n * AB\n *\n * @private\n * @param {Array>} segment - 2 vertex line segment\n * @returns {Array} coordinates [x, y]\n */\nfunction ab(segment) {\n var start = segment[0];\n var end = segment[1];\n return [end[0] - start[0], end[1] - start[1]];\n}\n\n/**\n * Cross Product\n *\n * @private\n * @param {Array} v1 coordinates [x, y]\n * @param {Array} v2 coordinates [x, y]\n * @returns {Array} Cross Product\n */\nfunction crossProduct(v1, v2) {\n return (v1[0] * v2[1]) - (v2[0] * v1[1]);\n}\n\n/**\n * Add\n *\n * @private\n * @param {Array} v1 coordinates [x, y]\n * @param {Array} v2 coordinates [x, y]\n * @returns {Array} Add\n */\nfunction add(v1, v2) {\n return [v1[0] + v2[0], v1[1] + v2[1]];\n}\n\n/**\n * Sub\n *\n * @private\n * @param {Array} v1 coordinates [x, y]\n * @param {Array} v2 coordinates [x, y]\n * @returns {Array} Sub\n */\nfunction sub(v1, v2) {\n return [v1[0] - v2[0], v1[1] - v2[1]];\n}\n\n/**\n * scalarMult\n *\n * @private\n * @param {number} s scalar\n * @param {Array} v coordinates [x, y]\n * @returns {Array} scalarMult\n */\nfunction scalarMult(s, v) {\n return [s * v[0], s * v[1]];\n}\n\n/**\n * Intersect Segments\n *\n * @private\n * @param {Array} a coordinates [x, y]\n * @param {Array} b coordinates [x, y]\n * @returns {Array} intersection\n */\nfunction intersectSegments(a, b) {\n var p = a[0];\n var r = ab(a);\n var q = b[0];\n var s = ab(b);\n\n var cross = crossProduct(r, s);\n var qmp = sub(q, p);\n var numerator = crossProduct(qmp, s);\n var t = numerator / cross;\n var intersection = add(p, scalarMult(t, r));\n return intersection;\n}\n\n/**\n * Is Parallel\n *\n * @private\n * @param {Array} a coordinates [x, y]\n * @param {Array} b coordinates [x, y]\n * @returns {boolean} true if a and b are parallel (or co-linear)\n */\nfunction isParallel(a, b) {\n var r = ab(a);\n var s = ab(b);\n return (crossProduct(r, s) === 0);\n}\n\n/**\n * Intersection\n *\n * @private\n * @param {Array} a coordinates [x, y]\n * @param {Array} b coordinates [x, y]\n * @returns {Array|boolean} true if a and b are parallel (or co-linear)\n */\nfunction intersection(a, b) {\n if (isParallel(a, b)) return false;\n return intersectSegments(a, b);\n}\n\nmodule.exports = intersection;\n","// JSTS. See https://github.com/bjornharrtell/jsts\n// Licenses:\n// https://github.com/bjornharrtell/jsts/blob/master/LICENSE_EDLv1.txt\n// https://github.com/bjornharrtell/jsts/blob/master/LICENSE_EPLv1.txt\n// https://github.com/bjornharrtell/jsts/blob/master/LICENSE_LICENSE_ES6_COLLECTIONS.txt\n!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?e(exports):\"function\"==typeof define&&define.amd?define([\"exports\"],e):e(t.jsts=t.jsts||{})}(this,function(t){\"use strict\";function e(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])}function n(){}function i(){}function r(){}function s(){}function o(){}function a(){}function u(){}function l(t){this.name=\"RuntimeException\",this.message=t,this.stack=(new Error).stack,Error.call(this,t)}function h(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t}function c(){if(0===arguments.length)l.call(this);else if(1===arguments.length){var t=arguments[0];l.call(this,t)}}function f(){}function g(){if(this.x=null,this.y=null,this.z=null,0===arguments.length)g.call(this,0,0);else if(1===arguments.length){var t=arguments[0];g.call(this,t.x,t.y,t.z)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];g.call(this,e,n,g.NULL_ORDINATE)}else if(3===arguments.length){var i=arguments[0],r=arguments[1],s=arguments[2];this.x=i,this.y=r,this.z=s}}function d(){if(this.dimensionsToTest=2,0===arguments.length)d.call(this,2);else if(1===arguments.length){var t=arguments[0];if(2!==t&&3!==t)throw new i(\"only 2 or 3 dimensions may be specified\");this.dimensionsToTest=t}}function p(){}function v(){}function m(t){this.message=t||\"\"}function y(){}function x(t){this.message=t||\"\"}function E(t){this.message=t||\"\"}function I(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function N(){if(I.apply(this),0===arguments.length);else if(1===arguments.length){var t=arguments[0];this.ensureCapacity(t.length),this.add(t,!0)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.ensureCapacity(e.length),this.add(e,n)}}function C(){if(this.minx=null,this.maxx=null,this.miny=null,this.maxy=null,0===arguments.length)this.init();else if(1===arguments.length){if(arguments[0]instanceof g){var t=arguments[0];this.init(t.x,t.x,t.y,t.y)}else if(arguments[0]instanceof C){var e=arguments[0];this.init(e)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];this.init(n.x,i.x,n.y,i.y)}else if(4===arguments.length){var r=arguments[0],s=arguments[1],o=arguments[2],a=arguments[3];this.init(r,s,o,a)}}function S(){}function w(){S.call(this,\"Projective point not representable on the Cartesian plane.\")}function L(){}function R(t,e){return t.interfaces_&&t.interfaces_().indexOf(e)>-1}function T(){}function P(t){this.str=t}function b(t){this.value=t}function O(){}function _(){if(this.hi=0,this.lo=0,0===arguments.length)this.init(0);else if(1===arguments.length){if(\"number\"==typeof arguments[0]){var t=arguments[0];this.init(t)}else if(arguments[0]instanceof _){var e=arguments[0];this.init(e)}else if(\"string\"==typeof arguments[0]){var n=arguments[0];_.call(this,_.parse(n))}}else if(2===arguments.length){var i=arguments[0],r=arguments[1];this.init(i,r)}}function M(){}function D(){}function A(){}function F(){if(this.x=null,this.y=null,this.w=null,0===arguments.length)this.x=0,this.y=0,this.w=1;else if(1===arguments.length){var t=arguments[0];this.x=t.x,this.y=t.y,this.w=1}else if(2===arguments.length){if(\"number\"==typeof arguments[0]&&\"number\"==typeof arguments[1]){var e=arguments[0],n=arguments[1];this.x=e,this.y=n,this.w=1}else if(arguments[0]instanceof F&&arguments[1]instanceof F){var i=arguments[0],r=arguments[1];this.x=i.y*r.w-r.y*i.w,this.y=r.x*i.w-i.x*r.w,this.w=i.x*r.y-r.x*i.y}else if(arguments[0]instanceof g&&arguments[1]instanceof g){var s=arguments[0],o=arguments[1];this.x=s.y-o.y,this.y=o.x-s.x,this.w=s.x*o.y-o.x*s.y}}else if(3===arguments.length){var a=arguments[0],u=arguments[1],l=arguments[2];this.x=a,this.y=u,this.w=l}else if(4===arguments.length){var h=arguments[0],c=arguments[1],f=arguments[2],d=arguments[3],p=h.y-c.y,v=c.x-h.x,m=h.x*c.y-c.x*h.y,y=f.y-d.y,x=d.x-f.x,E=f.x*d.y-d.x*f.y;this.x=v*E-x*m,this.y=y*m-p*E,this.w=p*x-y*v}}function G(){}function q(){}function B(){this.envelope=null,this.factory=null,this.SRID=null,this.userData=null;var t=arguments[0];this.factory=t,this.SRID=t.getSRID()}function z(){}function V(){}function k(){}function Y(){}function U(){}function X(){}function H(){}function W(){}function j(){}function K(){}function Z(){}function Q(){}function J(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function $(t){return null==t?$s:t.color}function tt(t){return null==t?null:t.parent}function et(t,e){null!==t&&(t.color=e)}function nt(t){return null==t?null:t.left}function it(t){return null==t?null:t.right}function rt(){this.root_=null,this.size_=0}function st(){}function ot(){}function at(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function ut(){}function lt(){}function ht(){}function ct(){}function ft(){this.geometries=null;var t=arguments[0],e=arguments[1];if(B.call(this,e),null===t&&(t=[]),B.hasNullElements(t))throw new i(\"geometries must not contain null elements\");this.geometries=t}function gt(){var t=arguments[0],e=arguments[1];ft.call(this,t,e)}function dt(){if(this.geom=null,this.geomFact=null,this.bnRule=null,this.endpointMap=null,1===arguments.length){var t=arguments[0];dt.call(this,t,V.MOD2_BOUNDARY_RULE)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.geom=e,this.geomFact=e.getFactory(),this.bnRule=n}}function pt(){this.count=null}function vt(){}function mt(){}function yt(){}function xt(){}function Et(){}function It(){}function Nt(){}function Ct(){}function St(){this.points=null;var t=arguments[0],e=arguments[1];B.call(this,e),this.init(t)}function wt(){}function Lt(){this.coordinates=null;var t=arguments[0],e=arguments[1];B.call(this,e),this.init(t)}function Rt(){}function Tt(){this.shell=null,this.holes=null;var t=arguments[0],e=arguments[1],n=arguments[2];if(B.call(this,n),null===t&&(t=this.getFactory().createLinearRing()),null===e&&(e=[]),B.hasNullElements(e))throw new i(\"holes must not contain null elements\");if(t.isEmpty()&&B.hasNonEmptyElements(e))throw new i(\"shell is empty but holes are not\");this.shell=t,this.holes=e}function Pt(){var t=arguments[0],e=arguments[1];ft.call(this,t,e)}function bt(){if(arguments[0]instanceof g&&arguments[1]instanceof ie){var t=arguments[0],e=arguments[1];bt.call(this,e.getCoordinateSequenceFactory().create(t),e)}else if(R(arguments[0],D)&&arguments[1]instanceof ie){var n=arguments[0],i=arguments[1];St.call(this,n,i),this.validateConstruction()}}function Ot(){var t=arguments[0],e=arguments[1];ft.call(this,t,e)}function _t(){if(this.factory=null,this.isUserDataCopied=!1,0===arguments.length);else if(1===arguments.length){var t=arguments[0];this.factory=t}}function Mt(){}function Dt(){}function At(){}function Ft(){}function Gt(){if(this.dimension=3,this.coordinates=null,1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];Gt.call(this,t,3)}else if(Number.isInteger(arguments[0])){var e=arguments[0];this.coordinates=new Array(e).fill(null);for(var n=0;n-1}function Yt(t){return this.has(t)?this._values[no]:void 0}function Ut(t,e){if(this.objectOnly&&e!==Object(e))throw new TypeError(\"Invalid value used as weak collection key\");if(e!==e||0===e)for(no=t.length;no--&&!Bt(t[no],e););else no=t.indexOf(e);return no>-1}function Xt(t){return Ut.call(this,this._keys,t)}function Ht(t,e){return this.has(t)?this._values[no]=e:this._values[this._keys.push(t)-1]=e,this}function Wt(){(this._keys||0).length=this._values.length=0}function jt(){return Qt(this._itp,this._keys)}function Kt(){return Qt(this._itp,this._values)}function Zt(){return Qt(this._itp,this._keys,this._values)}function Qt(t,e,n){var i=[0],r=!1;return t.push(i),{next:function(){var s,o=i[0];return!r&&o1,\"Node capacity must be greater than 1\"),this.nodeCapacity=t}}function ze(){}function Ve(){}function ke(){if(0===arguments.length)ke.call(this,ke.DEFAULT_NODE_CAPACITY);else if(1===arguments.length){var t=arguments[0];Be.call(this,t)}}function Ye(){var t=arguments[0];Ge.call(this,t)}function Ue(){}function Xe(){this.segString=null,this.coord=null,this.segmentIndex=null,this.segmentOctant=null,this._isInterior=null;var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3];this.segString=t,this.coord=new g(e),this.segmentIndex=n,this.segmentOctant=i,this._isInterior=!e.equals2D(t.getCoordinate(n))}function He(){this.nodeMap=new rt,this.edge=null;var t=arguments[0];this.edge=t}function We(){this.nodeList=null,this.edge=null,this.nodeIt=null,this.currNode=null,this.nextNode=null,this.currSegIndex=0;var t=arguments[0];this.nodeList=t,this.edge=t.getEdge(),this.nodeIt=t.iterator(),this.readNextNode()}function je(){}function Ke(){this.nodeList=new He(this),this.pts=null,this.data=null;var t=arguments[0],e=arguments[1];this.pts=t,this.data=e}function Ze(){this.tempEnv1=new C,this.tempEnv2=new C,this.overlapSeg1=new ce,this.overlapSeg2=new ce}function Qe(){this.pts=null,this.start=null,this.end=null,this.env=null,this.context=null,this.id=null;var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3];this.pts=t,this.start=e,this.end=n,this.context=i}function Je(){}function $e(){}function tn(){}function en(){if(this.segInt=null,0===arguments.length);else if(1===arguments.length){var t=arguments[0];this.setSegmentIntersector(t)}}function nn(){if(this.monoChains=new I,this.index=new ke,this.idCounter=0,this.nodedSegStrings=null,this.nOverlaps=0,0===arguments.length);else if(1===arguments.length){var t=arguments[0];en.call(this,t)}}function rn(){Ze.apply(this),this.si=null;var t=arguments[0];this.si=t}function sn(){if(this.pt=null,1===arguments.length){var t=arguments[0];l.call(this,t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];l.call(this,sn.msgWithCoord(e,n)),this.name=\"TopologyException\",this.pt=new g(n)}}function on(){}function an(){this.findAllIntersections=!1,this.isCheckEndSegmentsOnly=!1,this.li=null,this.interiorIntersection=null,this.intSegments=null,this.intersections=new I,this.intersectionCount=0,this.keepIntersections=!0;var t=arguments[0];this.li=t,this.interiorIntersection=null}function un(){this.li=new ae,this.segStrings=null,this.findAllIntersections=!1,this.segInt=null,this._isValid=!0;var t=arguments[0];this.segStrings=t}function ln(){this.nv=null;var t=arguments[0];this.nv=new un(ln.toSegmentStrings(t))}function hn(){this.mapOp=null;var t=arguments[0];this.mapOp=t}function cn(){}function fn(){if(this.location=null,1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];this.init(t.length)}else if(Number.isInteger(arguments[0])){var e=arguments[0];this.init(1),this.location[cn.ON]=e}else if(arguments[0]instanceof fn){var n=arguments[0];if(this.init(n.location.length),null!==n)for(var i=0;i=0?this.setComputationPrecision(i.getPrecisionModel()):this.setComputationPrecision(r.getPrecisionModel()),this.arg=new Array(2).fill(null),this.arg[0]=new $n(0,i,s),this.arg[1]=new $n(1,r,s)}}function ei(){this.pts=null,this._orientation=null;var t=arguments[0];this.pts=t,this._orientation=ei.orientation(t)}function ni(){this.edges=new I,this.ocaMap=new rt}function ii(){this.ptLocator=new Te,this.geomFact=null,this.resultGeom=null,this.graph=null,this.edgeList=new ni,this.resultPolyList=new I,this.resultLineList=new I,this.resultPointList=new I;var t=arguments[0],e=arguments[1];ti.call(this,t,e),this.graph=new Cn(new On),this.geomFact=t.getFactory()}function ri(){this.geom=new Array(2).fill(null),this.snapTolerance=null,this.cbr=null;var t=arguments[0],e=arguments[1];this.geom[0]=t,this.geom[1]=e,this.computeSnapTolerance()}function si(){this.geom=new Array(2).fill(null);var t=arguments[0],e=arguments[1];this.geom[0]=t,this.geom[1]=e}function oi(){this.factory=null,this.interiorPoint=null,this.maxWidth=0;var t=arguments[0];this.factory=t.getFactory(),this.add(t)}function ai(){this.poly=null,this.centreY=null,this.hiY=r.MAX_VALUE,this.loY=-r.MAX_VALUE;var t=arguments[0];this.poly=t,this.hiY=t.getEnvelopeInternal().getMaxY(),this.loY=t.getEnvelopeInternal().getMinY(),this.centreY=oi.avg(this.loY,this.hiY)}function ui(){this.centroid=null,this.minDistance=r.MAX_VALUE,this.interiorPoint=null;var t=arguments[0];this.centroid=t.getCentroid().getCoordinate(),this.addInterior(t),null===this.interiorPoint&&this.addEndpoints(t)}function li(){this.centroid=null,this.minDistance=r.MAX_VALUE,this.interiorPoint=null;var t=arguments[0];this.centroid=t.getCentroid().getCoordinate(),this.add(t)}function hi(){this.tempEnv1=new C,this.selectedSegment=new ce}function ci(){this.items=new I,this.subnode=[null,null]}function fi(){if(this.min=null,this.max=null,0===arguments.length)this.min=0,this.max=0;else if(1===arguments.length){var t=arguments[0];this.init(t.min,t.max)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.init(e,n)}}function gi(){}function di(t,e){var n,i,r,s,o={32:{d:127,c:128,b:0,a:0},64:{d:32752,c:0,b:0,a:0}},a={32:8,64:11}[t];if(s||(n=e<0||1/e<0,isFinite(e)||(s=o[t],n&&(s.d+=1<=2;)i++,r/=2;for(;r<1&&i>0;)i--,r*=2;i<=0&&(r/=2),32===t&&i>254&&(s={d:n?255:127,c:128,b:0,a:0},i=Math.pow(2,a)-1,r=0)}return i}function pi(){this.pt=0,this.level=0,this.interval=null;var t=arguments[0];this.computeKey(t)}function vi(){ci.apply(this),this.interval=null,this.centre=null,this.level=null;var t=arguments[0],e=arguments[1];this.interval=t,this.level=e,this.centre=(t.getMin()+t.getMax())/2}function mi(){}function yi(){ci.apply(this)}function xi(){this.root=null,this.minExtent=1,this.root=new yi}function Ei(){}function Ii(){this.ring=null,this.tree=null,this.crossings=0,this.interval=new fi;var t=arguments[0];this.ring=t,this.buildIndex()}function Ni(){hi.apply(this),this.mcp=null,this.p=null;var t=arguments[0],e=arguments[1];this.mcp=t,this.p=e}function Ci(){}function Si(){this.p0=null,this.p1=null,this.p2=null;var t=arguments[0],e=arguments[1],n=arguments[2];this.p0=t,this.p1=e,this.p2=n}function wi(){this.input=null,this.extremalPts=null,this.centre=null,this.radius=0;var t=arguments[0];this.input=t}function Li(){if(this.inputGeom=null,this.isConvex=null,this.convexHullPts=null,this.minBaseSeg=new ce,this.minWidthPt=null,this.minPtIndex=null,this.minWidth=0,1===arguments.length){var t=arguments[0];Li.call(this,t,!1)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.inputGeom=e,this.isConvex=n}}function Ri(){this.inputGeom=null,this.distanceTolerance=null;var t=arguments[0];this.inputGeom=t}function Ti(){xe.apply(this),this.distanceTolerance=null;var t=arguments[0];this.distanceTolerance=t}function Pi(){this._orig=null,this._sym=null,this._next=null;var t=arguments[0];this._orig=t}function bi(){this._isMarked=!1;var t=arguments[0];Pi.call(this,t)}function Oi(){this.vertexMap=new te}function _i(){this._isStart=!1;var t=arguments[0];bi.call(this,t)}function Mi(){Oi.apply(this)}function Di(){this.result=null,this.factory=null,this.graph=null,this.lines=new I,this.nodeEdgeStack=new pe,this.ringStartEdge=null,this.graph=new Mi}function Ai(){this.items=new I,this.subnode=new Array(4).fill(null)}function Fi(){this.pt=new g,this.level=0,this.env=null;var t=arguments[0];this.computeKey(t)}function Gi(){Ai.apply(this),this.env=null,this.centrex=null,this.centrey=null,this.level=null;var t=arguments[0],e=arguments[1];this.env=t,this.level=e,this.centrex=(t.getMinX()+t.getMaxX())/2,this.centrey=(t.getMinY()+t.getMaxY())/2}function qi(){Ai.apply(this)}function Bi(){this.root=null,this.minExtent=1,this.root=new qi}function zi(t){this.geometryFactory=t||new ie}function Vi(t){this.geometryFactory=t||new ie,this.precisionModel=this.geometryFactory.getPrecisionModel(),this.parser=new zi(this.geometryFactory)}function ki(){this.parser=new zi(this.geometryFactory)}function Yi(t){this.geometryFactory=t||new ie,this.precisionModel=this.geometryFactory.getPrecisionModel(),this.parser=new re(this.geometryFactory)}function Ui(t){return[t.x,t.y]}function Xi(t,e){this.geometryFactory=t||new ie,this.ol=e||\"undefined\"!=typeof ol&&ol}function Hi(){if(this.noder=null,this.scaleFactor=null,this.offsetX=null,this.offsetY=null,this.isScaled=!1,2===arguments.length){var t=arguments[0],e=arguments[1];Hi.call(this,t,e,0,0)}else if(4===arguments.length){var n=arguments[0],i=arguments[1];arguments[2],arguments[3];this.noder=n,this.scaleFactor=i,this.isScaled=!this.isIntegerPrecision()}}function Wi(){if(this.inputGeom=null,this.isClosedEndpointsInInterior=!0,this.nonSimpleLocation=null,1===arguments.length){var t=arguments[0];this.inputGeom=t}else if(2===arguments.length){var e=arguments[0],n=arguments[1];\nthis.inputGeom=e,this.isClosedEndpointsInInterior=!n.isInBoundary(2)}}function ji(){this.pt=null,this.isClosed=null,this.degree=null;var t=arguments[0];this.pt=t,this.isClosed=!1,this.degree=0}function Ki(){if(this.quadrantSegments=Ki.DEFAULT_QUADRANT_SEGMENTS,this.endCapStyle=Ki.CAP_ROUND,this.joinStyle=Ki.JOIN_ROUND,this.mitreLimit=Ki.DEFAULT_MITRE_LIMIT,this._isSingleSided=!1,this.simplifyFactor=Ki.DEFAULT_SIMPLIFY_FACTOR,0===arguments.length);else if(1===arguments.length){var t=arguments[0];this.setQuadrantSegments(t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.setQuadrantSegments(e),this.setEndCapStyle(n)}else if(4===arguments.length){var i=arguments[0],r=arguments[1],s=arguments[2],o=arguments[3];this.setQuadrantSegments(i),this.setEndCapStyle(r),this.setJoinStyle(s),this.setMitreLimit(o)}}function Zi(){this.minIndex=-1,this.minCoord=null,this.minDe=null,this.orientedDe=null}function Qi(){this.array_=[]}function Ji(){this.finder=null,this.dirEdgeList=new I,this.nodes=new I,this.rightMostCoord=null,this.env=null,this.finder=new Zi}function $i(){this.inputLine=null,this.distanceTol=null,this.isDeleted=null,this.angleOrientation=he.COUNTERCLOCKWISE;var t=arguments[0];this.inputLine=t}function tr(){this.ptList=null,this.precisionModel=null,this.minimimVertexDistance=0,this.ptList=new I}function er(){this.maxCurveSegmentError=0,this.filletAngleQuantum=null,this.closingSegLengthFactor=1,this.segList=null,this.distance=0,this.precisionModel=null,this.bufParams=null,this.li=null,this.s0=null,this.s1=null,this.s2=null,this.seg0=new ce,this.seg1=new ce,this.offset0=new ce,this.offset1=new ce,this.side=0,this._hasNarrowConcaveAngle=!1;var t=arguments[0],e=arguments[1],n=arguments[2];this.precisionModel=t,this.bufParams=e,this.li=new ae,this.filletAngleQuantum=Math.PI/2/e.getQuadrantSegments(),e.getQuadrantSegments()>=8&&e.getJoinStyle()===Ki.JOIN_ROUND&&(this.closingSegLengthFactor=er.MAX_CLOSING_SEG_LEN_FACTOR),this.init(n)}function nr(){this.distance=0,this.precisionModel=null,this.bufParams=null;var t=arguments[0],e=arguments[1];this.precisionModel=t,this.bufParams=e}function ir(){this.subgraphs=null,this.seg=new ce,this.cga=new he;var t=arguments[0];this.subgraphs=t}function rr(){this.upwardSeg=null,this.leftDepth=null;var t=arguments[0],e=arguments[1];this.upwardSeg=new ce(t),this.leftDepth=e}function sr(){this.inputGeom=null,this.distance=null,this.curveBuilder=null,this.curveList=new I;var t=arguments[0],e=arguments[1],n=arguments[2];this.inputGeom=t,this.distance=e,this.curveBuilder=n}function or(){this._hasIntersection=!1,this.hasProper=!1,this.hasProperInterior=!1,this.hasInterior=!1,this.properIntersectionPoint=null,this.li=null,this.isSelfIntersection=null,this.numIntersections=0,this.numInteriorIntersections=0,this.numProperIntersections=0,this.numTests=0;var t=arguments[0];this.li=t}function ar(){this.bufParams=null,this.workingPrecisionModel=null,this.workingNoder=null,this.geomFact=null,this.graph=null,this.edgeList=new ni;var t=arguments[0];this.bufParams=t}function ur(){this.li=new ae,this.segStrings=null;var t=arguments[0];this.segStrings=t}function lr(){this.li=null,this.pt=null,this.originalPt=null,this.ptScaled=null,this.p0Scaled=null,this.p1Scaled=null,this.scaleFactor=null,this.minx=null,this.maxx=null,this.miny=null,this.maxy=null,this.corner=new Array(4).fill(null),this.safeEnv=null;var t=arguments[0],e=arguments[1],n=arguments[2];if(this.originalPt=t,this.pt=t,this.scaleFactor=e,this.li=n,e<=0)throw new i(\"Scale factor must be non-zero\");1!==e&&(this.pt=new g(this.scale(t.x),this.scale(t.y)),this.p0Scaled=new g,this.p1Scaled=new g),this.initCorners(this.pt)}function hr(){this.index=null;var t=arguments[0];this.index=t}function cr(){hi.apply(this),this.hotPixel=null,this.parentEdge=null,this.hotPixelVertexIndex=null,this._isNodeAdded=!1;var t=arguments[0],e=arguments[1],n=arguments[2];this.hotPixel=t,this.parentEdge=e,this.hotPixelVertexIndex=n}function fr(){this.li=null,this.interiorIntersections=null;var t=arguments[0];this.li=t,this.interiorIntersections=new I}function gr(){this.pm=null,this.li=null,this.scaleFactor=null,this.noder=null,this.pointSnapper=null,this.nodedSegStrings=null;var t=arguments[0];this.pm=t,this.li=new ae,this.li.setPrecisionModel(t),this.scaleFactor=t.getScale()}function dr(){if(this.argGeom=null,this.distance=null,this.bufParams=new Ki,this.resultGeometry=null,this.saveException=null,1===arguments.length){var t=arguments[0];this.argGeom=t}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.argGeom=e,this.bufParams=n}}function pr(){this.comps=null;var t=arguments[0];this.comps=t}function vr(){if(this.component=null,this.segIndex=null,this.pt=null,2===arguments.length){var t=arguments[0],e=arguments[1];vr.call(this,t,vr.INSIDE_AREA,e)}else if(3===arguments.length){var n=arguments[0],i=arguments[1],r=arguments[2];this.component=n,this.segIndex=i,this.pt=r}}function mr(){this.pts=null;var t=arguments[0];this.pts=t}function yr(){this.locations=null;var t=arguments[0];this.locations=t}function xr(){if(this.geom=null,this.terminateDistance=0,this.ptLocator=new Te,this.minDistanceLocation=null,this.minDistance=r.MAX_VALUE,2===arguments.length){var t=arguments[0],e=arguments[1];xr.call(this,t,e,0)}else if(3===arguments.length){var n=arguments[0],i=arguments[1],s=arguments[2];this.geom=new Array(2).fill(null),this.geom[0]=n,this.geom[1]=i,this.terminateDistance=s}}function Er(){this.factory=null,this.directedEdges=new I,this.coordinates=null;var t=arguments[0];this.factory=t}function Ir(){this._isMarked=!1,this._isVisited=!1,this.data=null}function Nr(){Ir.apply(this),this.parentEdge=null,this.from=null,this.to=null,this.p0=null,this.p1=null,this.sym=null,this.edgeDirection=null,this.quadrant=null,this.angle=null;var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3];this.from=t,this.to=e,this.edgeDirection=i,this.p0=t.getCoordinate(),this.p1=n;var r=this.p1.x-this.p0.x,s=this.p1.y-this.p0.y;this.quadrant=Je.quadrant(r,s),this.angle=Math.atan2(s,r)}function Cr(){var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3];Nr.call(this,t,e,n,i)}function Sr(){if(Ir.apply(this),this.dirEdge=null,0===arguments.length);else if(2===arguments.length){var t=arguments[0],e=arguments[1];this.setDirectedEdges(t,e)}}function wr(){this.outEdges=new I,this.sorted=!1}function Lr(){if(Ir.apply(this),this.pt=null,this.deStar=null,1===arguments.length){var t=arguments[0];Lr.call(this,t,new wr)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.pt=e,this.deStar=n}}function Rr(){Sr.apply(this),this.line=null;var t=arguments[0];this.line=t}function Tr(){this.nodeMap=new rt}function Pr(){this.edges=new J,this.dirEdges=new J,this.nodeMap=new Tr}function br(){Pr.apply(this)}function Or(){this.graph=new br,this.mergedLineStrings=null,this.factory=null,this.edgeStrings=null}function _r(){this.edgeRing=null,this.next=null,this.label=-1;var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3];Nr.call(this,t,e,n,i)}function Mr(){Sr.apply(this),this.line=null;var t=arguments[0];this.line=t}function Dr(){this.geometryFactory=new ie,this.geomGraph=null,this.disconnectedRingcoord=null;var t=arguments[0];this.geomGraph=t}function Ar(){}function Fr(){if(this.edgeEnds=new I,1===arguments.length){var t=arguments[0];Fr.call(this,null,t)}else if(2===arguments.length){var e=(arguments[0],arguments[1]);En.call(this,e.getEdge(),e.getCoordinate(),e.getDirectedCoordinate(),new gn(e.getLabel())),this.insert(e)}}function Gr(){Pn.apply(this)}function qr(){var t=arguments[0],e=arguments[1];yn.call(this,t,e)}function Br(){Nn.apply(this)}function zr(){this.nodes=new xn(new Br)}function Vr(){this.li=new ae,this.geomGraph=null,this.nodeGraph=new zr,this.invalidPoint=null;var t=arguments[0];this.geomGraph=t}function kr(){this.graph=null,this.rings=new I,this.totalEnv=new C,this.index=null,this.nestedPt=null;var t=arguments[0];this.graph=t}function Yr(){if(this.errorType=null,this.pt=null,1===arguments.length){var t=arguments[0];Yr.call(this,t,null)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.errorType=e,null!==n&&(this.pt=n.copy())}}function Ur(){this.parentGeometry=null,this.isSelfTouchingRingFormingHoleValid=!1,this.validErr=null;var t=arguments[0];this.parentGeometry=t}function Xr(){this.factory=null,this.deList=new I,this.lowestEdge=null,this.ring=null,this.ringPts=null,this.holes=null,this.shell=null,this._isHole=null,this._isProcessed=!1,this._isIncludedSet=!1,this._isIncluded=!1;var t=arguments[0];this.factory=t}function Hr(){}function Wr(){Pr.apply(this),this.factory=null;var t=arguments[0];this.factory=t}function jr(){if(this.lineStringAdder=new Kr(this),this.graph=null,this.dangles=new I,this.cutEdges=new I,this.invalidRingLines=new I,this.holeList=null,this.shellList=null,this.polyList=null,this.isCheckingRingsValid=!0,this.extractOnlyPolygonal=null,this.geomFactory=null,0===arguments.length)jr.call(this,!1);else if(1===arguments.length){var t=arguments[0];this.extractOnlyPolygonal=t}}function Kr(){this.p=null;var t=arguments[0];this.p=t}function Zr(){this.li=new ae,this.ptLocator=new Te,this.arg=null,this.nodes=new xn(new Br),this.im=null,this.isolatedEdges=new I,this.invalidPoint=null;var t=arguments[0];this.arg=t}function Qr(){this.rectEnv=null;var t=arguments[0];this.rectEnv=t.getEnvelopeInternal()}function Jr(){this.li=new ae,this.rectEnv=null,this.diagUp0=null,this.diagUp1=null,this.diagDown0=null,this.diagDown1=null;var t=arguments[0];this.rectEnv=t,this.diagUp0=new g(t.getMinX(),t.getMinY()),this.diagUp1=new g(t.getMaxX(),t.getMaxY()),this.diagDown0=new g(t.getMinX(),t.getMaxY()),this.diagDown1=new g(t.getMaxX(),t.getMinY())}function $r(){this._isDone=!1}function ts(){this.rectangle=null,this.rectEnv=null;var t=arguments[0];this.rectangle=t,this.rectEnv=t.getEnvelopeInternal()}function es(){$r.apply(this),this.rectEnv=null,this._intersects=!1;var t=arguments[0];this.rectEnv=t}function ns(){$r.apply(this),this.rectSeq=null,this.rectEnv=null,this._containsPoint=!1;var t=arguments[0];this.rectSeq=t.getExteriorRing().getCoordinateSequence(),this.rectEnv=t.getEnvelopeInternal()}function is(){$r.apply(this),this.rectEnv=null,this.rectIntersector=null,this.hasIntersection=!1,this.p0=new g,this.p1=new g;var t=arguments[0];this.rectEnv=t.getEnvelopeInternal(),this.rectIntersector=new Jr(this.rectEnv)}function rs(){if(this._relate=null,2===arguments.length){var t=arguments[0],e=arguments[1];ti.call(this,t,e),this._relate=new Zr(this.arg)}else if(3===arguments.length){var n=arguments[0],i=arguments[1],r=arguments[2];ti.call(this,n,i,r),this._relate=new Zr(this.arg)}}function ss(){this.geomFactory=null,this.skipEmpty=!1,this.inputGeoms=null;var t=arguments[0];this.geomFactory=ss.extractFactory(t),this.inputGeoms=t}function os(){this.pointGeom=null,this.otherGeom=null,this.geomFact=null;var t=arguments[0],e=arguments[1];this.pointGeom=t,this.otherGeom=e,this.geomFact=e.getFactory()}function as(){this.sortIndex=-1,this.comps=null;var t=arguments[0],e=arguments[1];this.sortIndex=t,this.comps=e}function us(){this.inputPolys=null,this.geomFactory=null;var t=arguments[0];this.inputPolys=t,null===this.inputPolys&&(this.inputPolys=new I)}function ls(){if(this.polygons=new I,this.lines=new I,this.points=new I,this.geomFact=null,1===arguments.length){if(R(arguments[0],v)){var t=arguments[0];this.extract(t)}else if(arguments[0]instanceof B){var e=arguments[0];this.extract(e)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];this.geomFact=i,this.extract(n)}}function hs(){_t.CoordinateOperation.apply(this),this.targetPM=null,this.removeCollapsed=!0;var t=arguments[0],e=arguments[1];this.targetPM=t,this.removeCollapsed=e}function cs(){this.targetPM=null,this.removeCollapsed=!0,this.changePrecisionModel=!1,this.isPointwise=!1;var t=arguments[0];this.targetPM=t}function fs(){this.pts=null,this.usePt=null,this.distanceTolerance=null,this.seg=new ce;var t=arguments[0];this.pts=t}function gs(){this.inputGeom=null,this.distanceTolerance=null,this.isEnsureValidTopology=!0;var t=arguments[0];this.inputGeom=t}function ds(){xe.apply(this),this.isEnsureValidTopology=!0,this.distanceTolerance=null;var t=arguments[0],e=arguments[1];this.isEnsureValidTopology=t,this.distanceTolerance=e}function ps(){if(this.parent=null,this.index=null,2===arguments.length){var t=arguments[0],e=arguments[1];ps.call(this,t,e,null,-1)}else if(4===arguments.length){var n=arguments[0],i=arguments[1],r=arguments[2],s=arguments[3];ce.call(this,n,i),this.parent=r,this.index=s}}function vs(){if(this.parentLine=null,this.segs=null,this.resultSegs=new I,this.minimumSize=null,1===arguments.length){var t=arguments[0];vs.call(this,t,2)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.parentLine=e,this.minimumSize=n,this.init()}}function ms(){this.index=new Bi}function ys(){this.querySeg=null,this.items=new I;var t=arguments[0];this.querySeg=t}function xs(){this.li=new ae,this.inputIndex=new ms,this.outputIndex=new ms,this.line=null,this.linePts=null,this.distanceTolerance=0;var t=arguments[0],e=arguments[1];this.inputIndex=t,this.outputIndex=e}function Es(){this.inputIndex=new ms,this.outputIndex=new ms,this.distanceTolerance=0}function Is(){this.inputGeom=null,this.lineSimplifier=new Es,this.linestringMap=null;var t=arguments[0];this.inputGeom=t}function Ns(){xe.apply(this),this.linestringMap=null;var t=arguments[0];this.linestringMap=t}function Cs(){this.tps=null;var t=arguments[0];this.tps=t}function Ss(){this.seg=null,this.segLen=null,this.splitPt=null,this.minimumLen=0;var t=arguments[0];this.seg=t,this.segLen=t.getLength()}function ws(){}function Ls(){}function Rs(){}function Ts(){if(this.p=null,1===arguments.length){var t=arguments[0];this.p=new g(t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.p=new g(e,n)}else if(3===arguments.length){var i=arguments[0],r=arguments[1],s=arguments[2];this.p=new g(i,r,s)}}function Ps(){this._isOnConstraint=null,this.constraint=null;var t=arguments[0];Ts.call(this,t)}function bs(){this._rot=null,this.vertex=null,this.next=null,this.data=null}function Os(){this.subdiv=null,this.isUsingTolerance=!1;var t=arguments[0];this.subdiv=t,this.isUsingTolerance=t.getTolerance()>0}function _s(){}function Ms(){this.subdiv=null,this.lastEdge=null;var t=arguments[0];this.subdiv=t,this.init()}function Ds(){if(this.seg=null,1===arguments.length){if(\"string\"==typeof arguments[0]){var t=arguments[0];l.call(this,t)}else if(arguments[0]instanceof ce){var e=arguments[0];l.call(this,\"Locate failed to converge (at edge: \"+e+\"). Possible causes include invalid Subdivision topology or very close sites\"),this.seg=new ce(e)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];l.call(this,Ds.msgWithSpatial(n,i)),this.seg=new ce(i)}}function As(){}function Fs(){this.visitedKey=0,this.quadEdges=new I,this.startingEdge=null,this.tolerance=null,this.edgeCoincidenceTolerance=null,this.frameVertex=new Array(3).fill(null),this.frameEnv=null,this.locator=null,this.seg=new ce,this.triEdges=new Array(3).fill(null);var t=arguments[0],e=arguments[1];this.tolerance=e,this.edgeCoincidenceTolerance=e/Fs.EDGE_COINCIDENCE_TOL_FACTOR,this.createFrame(t),this.startingEdge=this.initSubdiv(),this.locator=new Ms(this)}function Gs(){}function qs(){this.triList=new I}function Bs(){this.triList=new I}function zs(){this.coordList=new N,this.triCoords=new I}function Vs(){if(this.ls=null,this.data=null,2===arguments.length){var t=arguments[0],e=arguments[1];this.ls=new ce(t,e)}else if(3===arguments.length){var n=arguments[0],i=arguments[1],r=arguments[2];this.ls=new ce(n,i),this.data=r}else if(6===arguments.length){var s=arguments[0],o=arguments[1],a=arguments[2],u=arguments[3],l=arguments[4],h=arguments[5];Vs.call(this,new g(s,o,a),new g(u,l,h))}else if(7===arguments.length){var c=arguments[0],f=arguments[1],d=arguments[2],p=arguments[3],v=arguments[4],m=arguments[5],y=arguments[6];Vs.call(this,new g(c,f,d),new g(p,v,m),y)}}function ks(){}function Ys(){if(this.p=null,this.data=null,this.left=null,this.right=null,this.count=null,2===arguments.length){var t=arguments[0],e=arguments[1];this.p=new g(t),this.left=null,this.right=null,this.count=1,this.data=e}else if(3===arguments.length){var n=arguments[0],i=arguments[1],r=arguments[2];this.p=new g(n,i),this.left=null,this.right=null,this.count=1,this.data=r}}function Us(){if(this.root=null,this.numberOfNodes=null,this.tolerance=null,0===arguments.length)Us.call(this,0);else if(1===arguments.length){var t=arguments[0];this.tolerance=t}}function Xs(){this.tolerance=null,this.matchNode=null,this.matchDist=0,this.p=null;var t=arguments[0],e=arguments[1];this.p=t,this.tolerance=e}function Hs(){this.initialVertices=null,this.segVertices=null,this.segments=new I,this.subdiv=null,this.incDel=null,this.convexHull=null,this.splitFinder=new Ls,this.kdt=null,this.vertexFactory=null,this.computeAreaEnv=null,this.splitPt=null,this.tolerance=null;var t=arguments[0],e=arguments[1];this.initialVertices=new I(t),this.tolerance=e,this.kdt=new Us(e)}function Ws(){this.siteCoords=null,this.tolerance=0,this.subdiv=null}function js(){this.siteCoords=null,this.constraintLines=null,this.tolerance=0,this.subdiv=null,this.constraintVertexMap=new rt}function Ks(){this.siteCoords=null,this.tolerance=0,this.subdiv=null,this.clipEnv=null,this.diagramEnv=null}function Zs(){}\"fill\"in Array.prototype||Object.defineProperty(Array.prototype,\"fill\",{configurable:!0,value:function(t){if(void 0===this||null===this)throw new TypeError(this+\" is not an object\");var e=Object(this),n=Math.max(Math.min(e.length,9007199254740991),0)||0,i=1 in arguments?parseInt(Number(arguments[1]),10)||0:0;i=i<0?Math.max(n+i,0):Math.min(i,n);var r=2 in arguments&&void 0!==arguments[2]?parseInt(Number(arguments[2]),10)||0:n;for(r=r<0?Math.max(n+arguments[2],0):Math.min(r,n);ie.x?1:this.ye.y?1:0},clone:function(){try{var t=null;return t}catch(t){if(t instanceof CloneNotSupportedException)return f.shouldNeverReachHere(\"this shouldn't happen because this class is Cloneable\"),null;throw t}finally{}},copy:function(){return new g(this)},toString:function(){return\"(\"+this.x+\", \"+this.y+\", \"+this.z+\")\"},distance3D:function(t){var e=this.x-t.x,n=this.y-t.y,i=this.z-t.z;return Math.sqrt(e*e+n*n+i*i)},distance:function(t){var e=this.x-t.x,n=this.y-t.y;return Math.sqrt(e*e+n*n)},hashCode:function(){var t=17;return t=37*t+g.hashCode(this.x),t=37*t+g.hashCode(this.y)},setCoordinate:function(t){this.x=t.x,this.y=t.y,this.z=t.z},interfaces_:function(){return[s,o,u]},getClass:function(){return g}}),g.hashCode=function(){if(1===arguments.length){var t=arguments[0],e=r.doubleToLongBits(t);return Math.trunc(e^e>>>32)}},e(d.prototype,{compare:function(t,e){var n=t,i=e,r=d.compare(n.x,i.x);if(0!==r)return r;var s=d.compare(n.y,i.y);if(0!==s)return s;if(this.dimensionsToTest<=2)return 0;var o=d.compare(n.z,i.z);return o},interfaces_:function(){return[a]},getClass:function(){return d}}),d.compare=function(t,e){return te?1:r.isNaN(t)?r.isNaN(e)?0:-1:r.isNaN(e)?1:0},g.DimensionalComparator=d,g.serialVersionUID=0x5cbf2c235c7e5800,g.NULL_ORDINATE=r.NaN,g.X=0,g.Y=1,g.Z=2,p.prototype.hasNext=function(){},p.prototype.next=function(){},p.prototype.remove=function(){},v.prototype.add=function(){},v.prototype.addAll=function(){},v.prototype.isEmpty=function(){},v.prototype.iterator=function(){},v.prototype.size=function(){},v.prototype.toArray=function(){},v.prototype.remove=function(){},m.prototype=new Error,m.prototype.name=\"IndexOutOfBoundsException\",y.prototype=Object.create(v.prototype),y.prototype.constructor=y,y.prototype.get=function(){},y.prototype.set=function(){},y.prototype.isEmpty=function(){},x.prototype=new Error,x.prototype.name=\"NoSuchElementException\",E.prototype=new Error,E.prototype.name=\"OperationNotSupported\",I.prototype=Object.create(y.prototype),I.prototype.constructor=I,I.prototype.ensureCapacity=function(){},I.prototype.interfaces_=function(){return[y,v]},I.prototype.add=function(t){return 1===arguments.length?this.array_.push(t):this.array_.splice(arguments[0],arguments[1]),!0},I.prototype.clear=function(){this.array_=[]},I.prototype.addAll=function(t){for(var e=t.iterator();e.hasNext();)this.add(e.next());return!0},I.prototype.set=function(t,e){var n=this.array_[t];return this.array_[t]=e,n},I.prototype.iterator=function(){return new Qs(this)},I.prototype.get=function(t){if(t<0||t>=this.size())throw new m;return this.array_[t]},I.prototype.isEmpty=function(){return 0===this.array_.length},I.prototype.size=function(){return this.array_.length},I.prototype.toArray=function(){for(var t=[],e=0,n=this.array_.length;e=1){var s=this.get(this.size()-1);if(s.equals2D(i))return null}I.prototype.add.call(this,i)}else if(arguments[0]instanceof Object&&\"boolean\"==typeof arguments[1]){var o=arguments[0],a=arguments[1];return this.add(o,a),!0}}else if(3===arguments.length){if(\"boolean\"==typeof arguments[2]&&arguments[0]instanceof Array&&\"boolean\"==typeof arguments[1]){var u=arguments[0],l=arguments[1],h=arguments[2];if(h)for(var c=0;c=0;c--)this.add(u[c],l);return!0}if(\"boolean\"==typeof arguments[2]&&Number.isInteger(arguments[0])&&arguments[1]instanceof g){var f=arguments[0],d=arguments[1],p=arguments[2];if(!p){var v=this.size();if(v>0){if(f>0){var m=this.get(f-1);if(m.equals2D(d))return null}if(fC&&(S=-1);for(var c=N;c!==C;c+=S)this.add(x[c],E);return!0}},closeRing:function(){this.size()>0&&this.add(new g(this.get(0)),!1)},interfaces_:function(){return[]},getClass:function(){return N}}),N.coordArrayType=new Array(0).fill(null),e(C.prototype,{getArea:function(){return this.getWidth()*this.getHeight()},equals:function(t){if(!(t instanceof C))return!1;var e=t;return this.isNull()?e.isNull():this.maxx===e.getMaxX()&&this.maxy===e.getMaxY()&&this.minx===e.getMinX()&&this.miny===e.getMinY()},intersection:function(t){if(this.isNull()||t.isNull()||!this.intersects(t))return new C;var e=this.minx>t.minx?this.minx:t.minx,n=this.miny>t.miny?this.miny:t.miny,i=this.maxx=this.minx&&e.getMaxX()<=this.maxx&&e.getMinY()>=this.miny&&e.getMaxY()<=this.maxy)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];return!this.isNull()&&(n>=this.minx&&n<=this.maxx&&i>=this.miny&&i<=this.maxy)}},intersects:function(){if(1===arguments.length){if(arguments[0]instanceof C){var t=arguments[0];return!this.isNull()&&!t.isNull()&&!(t.minx>this.maxx||t.maxxthis.maxy||t.maxythis.maxx||nthis.maxy||ithis.maxx&&(this.maxx=e.maxx),e.minythis.maxy&&(this.maxy=e.maxy))}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];this.isNull()?(this.minx=n,this.maxx=n,this.miny=i,this.maxy=i):(nthis.maxx&&(this.maxx=n),ithis.maxy&&(this.maxy=i))}},minExtent:function(){if(this.isNull())return 0;var t=this.getWidth(),e=this.getHeight();return te.minx?1:this.minye.miny?1:this.maxxe.maxx?1:this.maxye.maxy?1:0},translate:function(t,e){return this.isNull()?null:void this.init(this.getMinX()+t,this.getMaxX()+t,this.getMinY()+e,this.getMaxY()+e)},toString:function(){return\"Env[\"+this.minx+\" : \"+this.maxx+\", \"+this.miny+\" : \"+this.maxy+\"]\"},setToNull:function(){this.minx=0,this.maxx=-1,this.miny=0,this.maxy=-1},getHeight:function(){return this.isNull()?0:this.maxy-this.miny},maxExtent:function(){if(this.isNull())return 0;var t=this.getWidth(),e=this.getHeight();return t>e?t:e},expandBy:function(){if(1===arguments.length){var t=arguments[0];this.expandBy(t,t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];if(this.isNull())return null;this.minx-=e,this.maxx+=e,this.miny-=n,this.maxy+=n,(this.minx>this.maxx||this.miny>this.maxy)&&this.setToNull()}},contains:function(){if(1===arguments.length){if(arguments[0]instanceof C){var t=arguments[0];return this.covers(t)}if(arguments[0]instanceof g){var e=arguments[0];return this.covers(e)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];return this.covers(n,i)}},centre:function(){return this.isNull()?null:new g((this.getMinX()+this.getMaxX())/2,(this.getMinY()+this.getMaxY())/2)},init:function(){if(0===arguments.length)this.setToNull();else if(1===arguments.length){if(arguments[0]instanceof g){var t=arguments[0];this.init(t.x,t.x,t.y,t.y)}else if(arguments[0]instanceof C){var e=arguments[0];this.minx=e.minx,this.maxx=e.maxx,this.miny=e.miny,this.maxy=e.maxy}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];this.init(n.x,i.x,n.y,i.y)}else if(4===arguments.length){var r=arguments[0],s=arguments[1],o=arguments[2],a=arguments[3];rt.maxx&&(e=this.minx-t.maxx);var n=0;return this.maxyt.maxy&&(n=this.miny-t.maxy),0===e?n:0===n?e:Math.sqrt(e*e+n*n)},hashCode:function(){var t=17;return t=37*t+g.hashCode(this.minx),t=37*t+g.hashCode(this.maxx),t=37*t+g.hashCode(this.miny),t=37*t+g.hashCode(this.maxy)},interfaces_:function(){return[s,u]},getClass:function(){return C}}),C.intersects=function(){if(3===arguments.length){var t=arguments[0],e=arguments[1],n=arguments[2];return n.x>=(t.xe.x?t.x:e.x)&&n.y>=(t.ye.y?t.y:e.y)}if(4===arguments.length){var i=arguments[0],r=arguments[1],s=arguments[2],o=arguments[3],a=Math.min(s.x,o.x),u=Math.max(s.x,o.x),l=Math.min(i.x,r.x),h=Math.max(i.x,r.x);return!(l>u)&&(!(hu)&&!(hn?n:t}if(Number.isInteger(arguments[2])&&Number.isInteger(arguments[0])&&Number.isInteger(arguments[1])){var i=arguments[0],r=arguments[1],s=arguments[2];return is?s:i}},T.wrap=function(t,e){return t<0?e- -t%e:t%e},T.max=function(){if(3===arguments.length){var t=arguments[0],e=arguments[1],n=arguments[2],i=t;return e>i&&(i=e),n>i&&(i=n),i}if(4===arguments.length){var r=arguments[0],s=arguments[1],o=arguments[2],a=arguments[3],i=r;return s>i&&(i=s),o>i&&(i=o),a>i&&(i=a),i}},T.average=function(t,e){return(t+e)/2},T.LOG_10=Math.log(10),P.prototype.append=function(t){this.str+=t},P.prototype.setCharAt=function(t,e){this.str=this.str.substr(0,t)+e+this.str.substr(t+1)},P.prototype.toString=function(t){return this.str},b.prototype.intValue=function(){return this.value},b.prototype.compareTo=function(t){return this.valuet?1:0},b.isNaN=function(t){return Number.isNaN(t)},O.isWhitespace=function(t){return t<=32&&t>=0||127==t},O.toUpperCase=function(t){return t.toUpperCase()},e(_.prototype,{le:function(t){return this.hi9?(h=!0,c=\"9\"):c=\"0\"+l,o.append(c),n=n.subtract(_.valueOf(l)).multiply(_.TEN),h&&n.selfAdd(_.TEN);var f=!0,g=_.magnitude(n.hi);if(g<0&&Math.abs(g)>=a-u&&(f=!1),!f)break}return e[0]=i,o.toString()},sqr:function(){return this.multiply(this)},doubleValue:function(){return this.hi+this.lo},subtract:function(){if(arguments[0]instanceof _){var t=arguments[0];return this.add(t.negate())}if(\"number\"==typeof arguments[0]){var e=arguments[0];return this.add(-e)}},equals:function(){if(1===arguments.length){var t=arguments[0];return this.hi===t.hi&&this.lo===t.lo}},isZero:function(){return 0===this.hi&&0===this.lo},selfSubtract:function(){if(arguments[0]instanceof _){var t=arguments[0];return this.isNaN()?this:this.selfAdd(-t.hi,-t.lo)}if(\"number\"==typeof arguments[0]){var e=arguments[0];return this.isNaN()?this:this.selfAdd(-e,0)}},getSpecialNumberString:function(){return this.isZero()?\"0.0\":this.isNaN()?\"NaN \":null},min:function(t){return this.le(t)?this:t},selfDivide:function(){if(1===arguments.length){if(arguments[0]instanceof _){var t=arguments[0];return this.selfDivide(t.hi,t.lo)}if(\"number\"==typeof arguments[0]){var e=arguments[0];return this.selfDivide(e,0)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1],r=null,s=null,o=null,a=null,u=null,l=null,h=null,c=null;return u=this.hi/n,l=_.SPLIT*u,r=l-u,c=_.SPLIT*n,r=l-r,s=u-r,o=c-n,h=u*n,o=c-o,a=n-o,c=r*o-h+r*a+s*o+s*a,l=(this.hi-h-c+this.lo-u*i)/n,c=u+l,this.hi=c,this.lo=u-c+l,this}},dump:function(){return\"DD<\"+this.hi+\", \"+this.lo+\">\"},divide:function(){if(arguments[0]instanceof _){var t=arguments[0],e=null,n=null,i=null,s=null,o=null,a=null,u=null,l=null;o=this.hi/t.hi,a=_.SPLIT*o,e=a-o,l=_.SPLIT*t.hi,e=a-e,n=o-e,i=l-t.hi,u=o*t.hi,i=l-i,s=t.hi-i,l=e*i-u+e*s+n*i+n*s,a=(this.hi-u-l+this.lo-o*t.lo)/t.hi,l=o+a;var h=l,c=o-l+a;return new _(h,c)}if(\"number\"==typeof arguments[0]){var f=arguments[0];return r.isNaN(f)?_.createNaN():_.copy(this).selfDivide(f,0)}},ge:function(t){return this.hi>t.hi||this.hi===t.hi&&this.lo>=t.lo},pow:function(t){if(0===t)return _.valueOf(1);var e=new _(this),n=_.valueOf(1),i=Math.abs(t);if(i>1)for(;i>0;)i%2===1&&n.selfMultiply(e),i/=2,i>0&&(e=e.sqr());else n=e;return t<0?n.reciprocal():n},ceil:function(){if(this.isNaN())return _.NaN;var t=Math.ceil(this.hi),e=0;return t===this.hi&&(e=Math.ceil(this.lo)),new _(t,e)},compareTo:function(t){var e=t;return this.hie.hi?1:this.loe.lo?1:0},rint:function(){if(this.isNaN())return this;var t=this.add(.5);return t.floor()},setValue:function(){if(arguments[0]instanceof _){var t=arguments[0];return this.init(t),this}if(\"number\"==typeof arguments[0]){var e=arguments[0];return this.init(e),this}},max:function(t){return this.ge(t)?this:t},sqrt:function(){if(this.isZero())return _.valueOf(0);if(this.isNegative())return _.NaN;var t=1/Math.sqrt(this.hi),e=this.hi*t,n=_.valueOf(e),i=this.subtract(n.sqr()),r=i.hi*(.5*t);return n.add(r)},selfAdd:function(){if(1===arguments.length){if(arguments[0]instanceof _){var t=arguments[0];return this.selfAdd(t.hi,t.lo)}if(\"number\"==typeof arguments[0]){var e=arguments[0],n=null,i=null,r=null,s=null,o=null,a=null;return r=this.hi+e,o=r-this.hi,s=r-o,s=e-o+(this.hi-s),a=s+this.lo,n=r+a,i=a+(r-n),this.hi=n+i,this.lo=i+(n-this.hi),this}}else if(2===arguments.length){var u=arguments[0],l=arguments[1],n=null,i=null,h=null,c=null,r=null,s=null,o=null,a=null;r=this.hi+u,h=this.lo+l,o=r-this.hi,a=h-this.lo,s=r-o,c=h-a,s=u-o+(this.hi-s),c=l-a+(this.lo-c),o=s+h,n=r+o,i=o+(r-n),o=c+i;var f=n+o,g=o+(n-f);return this.hi=f,this.lo=g,this}},selfMultiply:function(){if(1===arguments.length){if(arguments[0]instanceof _){var t=arguments[0];return this.selfMultiply(t.hi,t.lo)}if(\"number\"==typeof arguments[0]){var e=arguments[0];return this.selfMultiply(e,0)}}else if(2===arguments.length){var n=arguments[0],i=arguments[1],r=null,s=null,o=null,a=null,u=null,l=null;u=_.SPLIT*this.hi,r=u-this.hi,l=_.SPLIT*n,r=u-r,s=this.hi-r,o=l-n,u=this.hi*n,o=l-o,a=n-o,l=r*o-u+r*a+s*o+s*a+(this.hi*i+this.lo*n);var h=u+l;r=u-h;var c=l+r;return this.hi=h,this.lo=c,this}},selfSqr:function(){return this.selfMultiply(this)},floor:function(){if(this.isNaN())return _.NaN;var t=Math.floor(this.hi),e=0;return t===this.hi&&(e=Math.floor(this.lo)),new _(t,e)},negate:function(){return this.isNaN()?this:new _((-this.hi),(-this.lo))},clone:function(){try{return null}catch(t){if(t instanceof CloneNotSupportedException)return null;throw t}finally{}},multiply:function(){if(arguments[0]instanceof _){var t=arguments[0];return t.isNaN()?_.createNaN():_.copy(this).selfMultiply(t)}if(\"number\"==typeof arguments[0]){var e=arguments[0];return r.isNaN(e)?_.createNaN():_.copy(this).selfMultiply(e,0)}},isNaN:function(){return r.isNaN(this.hi)},intValue:function(){return Math.trunc(this.hi)},toString:function(){var t=_.magnitude(this.hi);return t>=-3&&t<=20?this.toStandardNotation():this.toSciNotation()},toStandardNotation:function(){var t=this.getSpecialNumberString();if(null!==t)return t;var e=new Array(1).fill(null),n=this.extractSignificantDigits(!0,e),i=e[0]+1,r=n;if(\".\"===n.charAt(0))r=\"0\"+n;else if(i<0)r=\"0.\"+_.stringOfChar(\"0\",-i)+n;else if(n.indexOf(\".\")===-1){var s=i-n.length,o=_.stringOfChar(\"0\",s);r=n+o+\".0\"}return this.isNegative()?\"-\"+r:r},reciprocal:function(){var t=null,e=null,n=null,i=null,r=null,s=null,o=null,a=null;r=1/this.hi,s=_.SPLIT*r,t=s-r,a=_.SPLIT*this.hi,t=s-t,e=r-t,n=a-this.hi,o=r*this.hi,n=a-n,i=this.hi-n,a=t*n-o+t*i+e*n+e*i,s=(1-o-a-r*this.lo)/this.hi;var u=r+s,l=r-u+s;return new _(u,l)},toSciNotation:function(){if(this.isZero())return _.SCI_NOT_ZERO;var t=this.getSpecialNumberString();if(null!==t)return t;var e=new Array(1).fill(null),n=this.extractSignificantDigits(!1,e),i=_.SCI_NOT_EXPONENT_CHAR+e[0];if(\"0\"===n.charAt(0))throw new IllegalStateException(\"Found leading zero: \"+n);var r=\"\";n.length>1&&(r=n.substring(1));var s=n.charAt(0)+\".\"+r;return this.isNegative()?\"-\"+s+i:s+i},abs:function(){return this.isNaN()?_.NaN:this.isNegative()?this.negate():new _(this)},isPositive:function(){return this.hi>0||0===this.hi&&this.lo>0},lt:function(t){return this.hit.hi||this.hi===t.hi&&this.lo>t.lo},isNegative:function(){return this.hi<0||0===this.hi&&this.lo<0},trunc:function(){return this.isNaN()?_.NaN:this.isPositive()?this.floor():this.ceil()},signum:function(){return this.hi>0?1:this.hi<0?-1:this.lo>0?1:this.lo<0?-1:0},interfaces_:function(){return[u,s,o]},getClass:function(){return _}}),_.sqr=function(t){return _.valueOf(t).selfMultiply(t)},_.valueOf=function(){if(\"string\"==typeof arguments[0]){var t=arguments[0];return _.parse(t)}if(\"number\"==typeof arguments[0]){var e=arguments[0];return new _(e)}},_.sqrt=function(t){return _.valueOf(t).sqrt()},_.parse=function(t){for(var e=0,n=t.length;O.isWhitespace(t.charAt(e));)e++;var i=!1;if(e=n)break;var l=t.charAt(e);if(e++,O.isDigit(l)){var h=l-\"0\";s.selfMultiply(_.TEN),s.selfAdd(h),o++}else{if(\".\"!==l){if(\"e\"===l||\"E\"===l){var c=t.substring(e);try{u=b.parseInt(c)}catch(e){throw e instanceof NumberFormatException?new NumberFormatException(\"Invalid exponent \"+c+\" in string \"+t):e}finally{}break}throw new NumberFormatException(\"Unexpected character '\"+l+\"' at position \"+e+\" in string \"+t)}a=o}}var f=s,g=o-a-u;if(0===g)f=s;else if(g>0){var d=_.TEN.pow(g);f=s.divide(d)}else if(g<0){var d=_.TEN.pow(-g);f=s.multiply(d)}return i?f.negate():f},_.createNaN=function(){return new _(r.NaN,r.NaN)},_.copy=function(t){return new _(t)},_.magnitude=function(t){var e=Math.abs(t),n=Math.log(e)/Math.log(10),i=Math.trunc(Math.floor(n)),r=Math.pow(10,i);return 10*r<=e&&(i+=1),i},_.stringOfChar=function(t,e){for(var n=new P,i=0;i0){if(s<=0)return M.signum(o);i=r+s}else{if(!(r<0))return M.signum(o);if(s>=0)return M.signum(o);i=-r-s}var a=M.DP_SAFE_EPSILON*i;return o>=a||-o>=a?M.signum(o):2},M.signum=function(t){return t>0?1:t<0?-1:0},M.DP_SAFE_EPSILON=1e-15,e(D.prototype,{setOrdinate:function(t,e,n){},size:function(){},getOrdinate:function(t,e){},getCoordinate:function(){if(1===arguments.length){arguments[0]}else if(2===arguments.length){arguments[0],arguments[1]}},getCoordinateCopy:function(t){},getDimension:function(){},getX:function(t){},clone:function(){},expandEnvelope:function(t){},copy:function(){},getY:function(t){},toCoordinateArray:function(){},interfaces_:function(){return[o]},getClass:function(){return D}}),D.X=0,D.Y=1,D.Z=2,D.M=3,A.arraycopy=function(t,e,n,i,r){for(var s=0,o=e;o0},interfaces_:function(){return[V]},getClass:function(){return Y}}),e(U.prototype,{isInBoundary:function(t){return t>1},interfaces_:function(){return[V]},getClass:function(){return U}}),e(X.prototype,{isInBoundary:function(t){return 1===t},interfaces_:function(){return[V]},getClass:function(){return X}}),V.Mod2BoundaryNodeRule=k,V.EndPointBoundaryNodeRule=Y,V.MultiValentEndPointBoundaryNodeRule=U,V.MonoValentEndPointBoundaryNodeRule=X,V.MOD2_BOUNDARY_RULE=new k,V.ENDPOINT_BOUNDARY_RULE=new Y,V.MULTIVALENT_ENDPOINT_BOUNDARY_RULE=new U,V.MONOVALENT_ENDPOINT_BOUNDARY_RULE=new X,V.OGC_SFS_BOUNDARY_RULE=V.MOD2_BOUNDARY_RULE,e(H.prototype,{interfaces_:function(){return[]},getClass:function(){return H}}),H.isRing=function(t){return!(t.length<4)&&!!t[0].equals2D(t[t.length-1])},H.ptNotInList=function(t,e){for(var n=0;n=t?e:[]},H.indexOf=function(t,e){for(var n=0;n0)&&(e=t[n]);return e},H.extract=function(t,e,n){e=T.clamp(e,0,t.length),n=T.clamp(n,-1,t.length);var i=n-e+1;n<0&&(i=0),e>=t.length&&(i=0),ni.length)return 1;if(0===n.length)return 0;var r=H.compare(n,i),s=H.isEqualReversed(n,i);return s?0:r},OLDcompare:function(t,e){var n=t,i=e;if(n.lengthi.length)return 1;if(0===n.length)return 0;for(var r=H.increasingDirection(n),s=H.increasingDirection(i),o=r>0?0:n.length-1,a=s>0?0:n.length-1,u=0;u0))return e.value;e=e.right}}return null},rt.prototype.put=function(t,e){if(null===this.root_)return this.root_={key:t,value:e,left:null,right:null,parent:null,color:$s,getValue:function(){return this.value},getKey:function(){return this.key}},this.size_=1,null;var n,i,r=this.root_;do if(n=r,i=t.compareTo(r.key),i<0)r=r.left;else{if(!(i>0)){var s=r.value;return r.value=e,s}r=r.right}while(null!==r);var o={key:t,left:null,right:null,value:e,parent:n,color:$s,getValue:function(){return this.value},getKey:function(){return this.key}};return i<0?n.left=o:n.right=o,this.fixAfterInsertion(o),this.size_++,null},rt.prototype.fixAfterInsertion=function(t){for(t.color=to;null!=t&&t!=this.root_&&t.parent.color==to;)if(tt(t)==nt(tt(tt(t)))){var e=it(tt(tt(t)));$(e)==to?(et(tt(t),$s),et(e,$s),et(tt(tt(t)),to),t=tt(tt(t))):(t==it(tt(t))&&(t=tt(t),this.rotateLeft(t)),et(tt(t),$s),et(tt(tt(t)),to),this.rotateRight(tt(tt(t))))}else{var e=nt(tt(tt(t)));$(e)==to?(et(tt(t),$s),et(e,$s),et(tt(tt(t)),to),t=tt(tt(t))):(t==nt(tt(t))&&(t=tt(t),this.rotateRight(t)),et(tt(t),$s),et(tt(tt(t)),to),this.rotateLeft(tt(tt(t))))}this.root_.color=$s},rt.prototype.values=function(){var t=new I,e=this.getFirstEntry();if(null!==e)for(t.add(e.value);null!==(e=rt.successor(e));)t.add(e.value);return t},rt.prototype.entrySet=function(){var t=new J,e=this.getFirstEntry();if(null!==e)for(t.add(e);null!==(e=rt.successor(e));)t.add(e);return t},rt.prototype.rotateLeft=function(t){if(null!=t){var e=t.right;t.right=e.left,null!=e.left&&(e.left.parent=t),e.parent=t.parent,null==t.parent?this.root_=e:t.parent.left==t?t.parent.left=e:t.parent.right=e,e.left=t,t.parent=e}},rt.prototype.rotateRight=function(t){if(null!=t){var e=t.left;t.left=e.right,null!=e.right&&(e.right.parent=t),e.parent=t.parent,null==t.parent?this.root_=e:t.parent.right==t?t.parent.right=e:t.parent.left=e,e.right=t,t.parent=e}},rt.prototype.getFirstEntry=function(){var t=this.root_;if(null!=t)for(;null!=t.left;)t=t.left;return t},rt.successor=function(t){if(null===t)return null;if(null!==t.right){for(var e=t.right;null!==e.left;)e=e.left;return e}for(var e=t.parent,n=t;null!==e&&n===e.right;)n=e,e=e.parent;return e},rt.prototype.size=function(){return this.size_},e(st.prototype,{interfaces_:function(){return[]},getClass:function(){return st}}),ot.prototype=new Q,at.prototype=new ot,at.prototype.contains=function(t){for(var e=0,n=this.array_.length;e=0;){var o=r.substring(0,s);i.add(o),r=r.substring(s+n),s=r.indexOf(e)}r.length>0&&i.add(r);for(var a=new Array(i.size()).fill(null),u=0;u0)for(var s=r;s0&&i.append(\" \");for(var s=0;s0&&i.append(\",\"),i.append(Nt.toString(t.getOrdinate(r,s)))}return i.append(\")\"),i.toString()}},Ct.ensureValidRing=function(t,e){var n=e.size();if(0===n)return e;if(n<=3)return Ct.createClosedRing(t,e,4);var i=e.getOrdinate(0,D.X)===e.getOrdinate(n-1,D.X)&&e.getOrdinate(0,D.Y)===e.getOrdinate(n-1,D.Y);return i?e:Ct.createClosedRing(t,e,n+1)},Ct.createClosedRing=function(t,e,n){var i=t.create(n,e.getDimension()),r=e.size();Ct.copy(e,0,i,0,r);for(var s=r;s0&&Ct.reverse(this.points),null}},getCoordinate:function(){return this.isEmpty()?null:this.points.getCoordinate(0)},getBoundaryDimension:function(){return this.isClosed()?lt.FALSE:0},isClosed:function(){return!this.isEmpty()&&this.getCoordinateN(0).equals2D(this.getCoordinateN(this.getNumPoints()-1))},getEndPoint:function(){return this.isEmpty()?null:this.getPointN(this.getNumPoints()-1)},getDimension:function(){return 1},getLength:function(){return he.computeLength(this.points)},getNumPoints:function(){return this.points.size()},reverse:function(){var t=this.points.copy();Ct.reverse(t);var e=this.getFactory().createLineString(t);return e},compareToSameClass:function(){if(1===arguments.length){for(var t=arguments[0],e=t,n=0,i=0;n= 2)\");this.points=t},isCoordinate:function(t){for(var e=0;e=1&&this.getCoordinateSequence().size()= 4)\")},getGeometryType:function(){return\"LinearRing\"},copy:function(){return new bt(this.points.copy(),this.factory)},interfaces_:function(){return[]},getClass:function(){return bt}}),bt.MINIMUM_VALID_SIZE=4,bt.serialVersionUID=-0x3b229e262367a600,h(Ot,ft),e(Ot.prototype,{getSortIndex:function(){return B.SORTINDEX_MULTIPOLYGON},equalsExact:function(){if(2===arguments.length){var t=arguments[0],e=arguments[1];return!!this.isEquivalentClass(t)&&ft.prototype.equalsExact.call(this,t,e)}return ft.prototype.equalsExact.apply(this,arguments)},getBoundaryDimension:function(){return 1},getDimension:function(){return 2},reverse:function(){for(var t=this.geometries.length,e=new Array(t).fill(null),n=0;n0?e.createPoint(n[0]):e.createPoint():t},interfaces_:function(){return[Mt]},getClass:function(){return At}}),e(Ft.prototype,{edit:function(t,e){return t instanceof bt?e.createLinearRing(this.edit(t.getCoordinateSequence(),t)):t instanceof St?e.createLineString(this.edit(t.getCoordinateSequence(),t)):t instanceof Lt?e.createPoint(this.edit(t.getCoordinateSequence(),t)):t},interfaces_:function(){return[Mt]},getClass:function(){return Ft}}),_t.NoOpGeometryOperation=Dt,_t.CoordinateOperation=At,_t.CoordinateSequenceOperation=Ft,e(Gt.prototype,{setOrdinate:function(t,e,n){switch(e){case D.X:this.coordinates[t].x=n;break;case D.Y:this.coordinates[t].y=n;break;case D.Z:this.coordinates[t].z=n;break;default:throw new i(\"invalid ordinateIndex\")}},size:function(){return this.coordinates.length},getOrdinate:function(t,e){switch(e){case D.X:return this.coordinates[t].x;case D.Y:return this.coordinates[t].y;case D.Z:return this.coordinates[t].z}return r.NaN},getCoordinate:function(){if(1===arguments.length){var t=arguments[0];return this.coordinates[t]}if(2===arguments.length){var e=arguments[0],n=arguments[1];n.x=this.coordinates[e].x,n.y=this.coordinates[e].y,n.z=this.coordinates[e].z}},getCoordinateCopy:function(t){return new g(this.coordinates[t])},getDimension:function(){return this.dimension},getX:function(t){return this.coordinates[t].x},clone:function(){for(var t=new Array(this.size()).fill(null),e=0;e0){var t=new P(17*this.coordinates.length);t.append(\"(\"),t.append(this.coordinates[0]);for(var e=1;e3&&(i=3),i<2?new Gt(n):new Gt(n,i)}},interfaces_:function(){return[G,u]},getClass:function(){return qt}}),qt.instance=function(){return qt.instanceObject},qt.serialVersionUID=-0x38e49fa6cf6f2e00,qt.instanceObject=new qt;var no,io=Object.defineProperty,ro=zt({delete:kt,has:Xt,get:Yt,set:Ht,keys:jt,values:Kt,entries:Zt,forEach:$t,clear:Wt}),so=\"undefined\"!=typeof Map&&Map.prototype.values?Map:ro;te.prototype=new K,te.prototype.get=function(t){return this.map_.get(t)||null},te.prototype.put=function(t,e){return this.map_.set(t,e),e},te.prototype.values=function(){for(var t=new I,e=this.map_.values(),n=e.next();!n.done;)t.add(n.value),n=e.next();return t},te.prototype.entrySet=function(){var t=new J;return this.map_.entries().forEach(function(e){return t.add(e)}),t},te.prototype.size=function(){return this.map_.size()},e(ee.prototype,{equals:function(t){if(!(t instanceof ee))return!1;var e=t;return this.modelType===e.modelType&&this.scale===e.scale},compareTo:function(t){var e=t,n=this.getMaximumSignificantDigits(),i=e.getMaximumSignificantDigits();return new b(n).compareTo(new b(i))},getScale:function(){return this.scale},isFloating:function(){return this.modelType===ee.FLOATING||this.modelType===ee.FLOATING_SINGLE},getType:function(){return this.modelType},toString:function(){var t=\"UNKNOWN\";return this.modelType===ee.FLOATING?t=\"Floating\":this.modelType===ee.FLOATING_SINGLE?t=\"Floating-Single\":this.modelType===ee.FIXED&&(t=\"Fixed (Scale=\"+this.getScale()+\")\"),t},makePrecise:function(){if(\"number\"==typeof arguments[0]){var t=arguments[0];if(r.isNaN(t))return t;if(this.modelType===ee.FLOATING_SINGLE){var e=t;return e}return this.modelType===ee.FIXED?Math.round(t*this.scale)/this.scale:t}if(arguments[0]instanceof g){var n=arguments[0];if(this.modelType===ee.FLOATING)return null;n.x=this.makePrecise(n.x),n.y=this.makePrecise(n.y)}},getMaximumSignificantDigits:function(){var t=16;return this.modelType===ee.FLOATING?t=16:this.modelType===ee.FLOATING_SINGLE?t=6:this.modelType===ee.FIXED&&(t=1+Math.trunc(Math.ceil(Math.log(this.getScale())/Math.log(10)))),t},setScale:function(t){this.scale=Math.abs(t)},interfaces_:function(){return[u,s]},getClass:function(){return ee}}),ee.mostPrecise=function(t,e){return t.compareTo(e)>=0?t:e},e(ne.prototype,{readResolve:function(){return ne.nameToTypeMap.get(this.name)},toString:function(){return this.name},interfaces_:function(){return[u]},getClass:function(){return ne}}),ne.serialVersionUID=-552860263173159e4,ne.nameToTypeMap=new te,ee.Type=ne,ee.serialVersionUID=0x6bee6404e9a25c00,ee.FIXED=new ne(\"FIXED\"),ee.FLOATING=new ne(\"FLOATING\"),ee.FLOATING_SINGLE=new ne(\"FLOATING SINGLE\"),ee.maximumPreciseValue=9007199254740992,e(ie.prototype,{toGeometry:function(t){return t.isNull()?this.createPoint(null):t.getMinX()===t.getMaxX()&&t.getMinY()===t.getMaxY()?this.createPoint(new g(t.getMinX(),t.getMinY())):t.getMinX()===t.getMaxX()||t.getMinY()===t.getMaxY()?this.createLineString([new g(t.getMinX(),t.getMinY()),new g(t.getMaxX(),t.getMaxY())]):this.createPolygon(this.createLinearRing([new g(t.getMinX(),t.getMinY()),new g(t.getMinX(),t.getMaxY()),new g(t.getMaxX(),t.getMaxY()),new g(t.getMaxX(),t.getMinY()),new g(t.getMinX(),t.getMinY())]),null)},createLineString:function(){if(0===arguments.length)return this.createLineString(this.getCoordinateSequenceFactory().create([]));if(1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];return this.createLineString(null!==t?this.getCoordinateSequenceFactory().create(t):null)}if(R(arguments[0],D)){var e=arguments[0];return new St(e,this)}}},createMultiLineString:function(){if(0===arguments.length)return new gt(null,this);if(1===arguments.length){var t=arguments[0];return new gt(t,this)}},buildGeometry:function(t){for(var e=null,n=!1,i=!1,r=t.iterator();r.hasNext();){var s=r.next(),o=s.getClass();null===e&&(e=o),o!==e&&(n=!0),s.isGeometryCollectionOrDerived()&&(i=!0)}if(null===e)return this.createGeometryCollection();if(n||i)return this.createGeometryCollection(ie.toGeometryArray(t));var a=t.iterator().next(),u=t.size()>1;if(u){if(a instanceof Tt)return this.createMultiPolygon(ie.toPolygonArray(t));if(a instanceof St)return this.createMultiLineString(ie.toLineStringArray(t));if(a instanceof Lt)return this.createMultiPoint(ie.toPointArray(t));f.shouldNeverReachHere(\"Unhandled class: \"+a.getClass().getName())}return a},createMultiPointFromCoords:function(t){return this.createMultiPoint(null!==t?this.getCoordinateSequenceFactory().create(t):null)},createPoint:function(){if(0===arguments.length)return this.createPoint(this.getCoordinateSequenceFactory().create([]));if(1===arguments.length){if(arguments[0]instanceof g){var t=arguments[0];return this.createPoint(null!==t?this.getCoordinateSequenceFactory().create([t]):null)}if(R(arguments[0],D)){var e=arguments[0];return new Lt(e,this)}}},getCoordinateSequenceFactory:function(){return this.coordinateSequenceFactory},createPolygon:function(){if(0===arguments.length)return new Tt(null,null,this);if(1===arguments.length){if(R(arguments[0],D)){var t=arguments[0];return this.createPolygon(this.createLinearRing(t))}if(arguments[0]instanceof Array){var e=arguments[0];return this.createPolygon(this.createLinearRing(e))}if(arguments[0]instanceof bt){var n=arguments[0];return this.createPolygon(n,null)}}else if(2===arguments.length){var i=arguments[0],r=arguments[1];return new Tt(i,r,this)}},getSRID:function(){return this.SRID},createGeometryCollection:function(){if(0===arguments.length)return new ft(null,this);if(1===arguments.length){var t=arguments[0];return new ft(t,this)}},createGeometry:function(t){var e=new _t(this);return e.edit(t,{edit:function(){if(2===arguments.length){var t=arguments[0];arguments[1];return this.coordinateSequenceFactory.create(t)}}})},getPrecisionModel:function(){return this.precisionModel},createLinearRing:function(){if(0===arguments.length)return this.createLinearRing(this.getCoordinateSequenceFactory().create([]));if(1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];return this.createLinearRing(null!==t?this.getCoordinateSequenceFactory().create(t):null)}if(R(arguments[0],D)){var e=arguments[0];return new bt(e,this)}}},createMultiPolygon:function(){if(0===arguments.length)return new Ot(null,this);if(1===arguments.length){var t=arguments[0];return new Ot(t,this)}},createMultiPoint:function(){if(0===arguments.length)return new Pt(null,this);if(1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];return new Pt(t,this)}if(arguments[0]instanceof Array){var e=arguments[0];return this.createMultiPoint(null!==e?this.getCoordinateSequenceFactory().create(e):null)}if(R(arguments[0],D)){var n=arguments[0];if(null===n)return this.createMultiPoint(new Array(0).fill(null));for(var i=new Array(n.size()).fill(null),r=0;rn?(this.intLineIndex[t][0]=0,this.intLineIndex[t][1]=1):(this.intLineIndex[t][0]=1,this.intLineIndex[t][1]=0)}},isProper:function(){return this.hasIntersection()&&this._isProper},setPrecisionModel:function(t){this.precisionModel=t},isInteriorIntersection:function(){if(0===arguments.length)return!!this.isInteriorIntersection(0)||!!this.isInteriorIntersection(1);if(1===arguments.length){for(var t=arguments[0],e=0;er?i:r;else{var o=Math.abs(t.x-e.x),a=Math.abs(t.y-e.y);s=i>r?o:a,0!==s||t.equals(e)||(s=Math.max(o,a))}return f.isTrue(!(0===s&&!t.equals(e)),\"Bad distance calculation\"),s},oe.nonRobustComputeEdgeDistance=function(t,e,n){var i=t.x-e.x,r=t.y-e.y,s=Math.sqrt(i*i+r*r);return f.isTrue(!(0===s&&!t.equals(e)),\"Invalid distance calculation\"),s},oe.DONT_INTERSECT=0,oe.DO_INTERSECT=1,oe.COLLINEAR=2,oe.NO_INTERSECTION=0,oe.POINT_INTERSECTION=1,oe.COLLINEAR_INTERSECTION=2,h(ae,oe),e(ae.prototype,{isInSegmentEnvelopes:function(t){var e=new C(this.inputLines[0][0],this.inputLines[0][1]),n=new C(this.inputLines[1][0],this.inputLines[1][1]);return e.contains(t)&&n.contains(t)},computeIntersection:function(){if(3!==arguments.length)return oe.prototype.computeIntersection.apply(this,arguments);var t=arguments[0],e=arguments[1],n=arguments[2];return this._isProper=!1,C.intersects(e,n,t)&&0===he.orientationIndex(e,n,t)&&0===he.orientationIndex(n,e,t)?(this._isProper=!0,(t.equals(e)||t.equals(n))&&(this._isProper=!1),this.result=oe.POINT_INTERSECTION,null):void(this.result=oe.NO_INTERSECTION)},normalizeToMinimum:function(t,e,n,i,r){r.x=this.smallestInAbsValue(t.x,e.x,n.x,i.x),r.y=this.smallestInAbsValue(t.y,e.y,n.y,i.y),t.x-=r.x,t.y-=r.y,e.x-=r.x,e.y-=r.y,n.x-=r.x,n.y-=r.y,i.x-=r.x,i.y-=r.y},safeHCoordinateIntersection:function(t,e,n,i){var r=null;try{r=F.intersection(t,e,n,i)}catch(s){if(!(s instanceof w))throw s;r=ae.nearestEndpoint(t,e,n,i)}finally{}return r},intersection:function(t,e,n,i){var r=this.intersectionWithNormalization(t,e,n,i);return this.isInSegmentEnvelopes(r)||(r=new g(ae.nearestEndpoint(t,e,n,i))),null!==this.precisionModel&&this.precisionModel.makePrecise(r),r},smallestInAbsValue:function(t,e,n,i){var r=t,s=Math.abs(r);return Math.abs(e)1e-4&&A.out.println(\"Distance = \"+r.distance(s))},intersectionWithNormalization:function(t,e,n,i){var r=new g(t),s=new g(e),o=new g(n),a=new g(i),u=new g;this.normalizeToEnvCentre(r,s,o,a,u);var l=this.safeHCoordinateIntersection(r,s,o,a);return l.x+=u.x,l.y+=u.y,l},computeCollinearIntersection:function(t,e,n,i){var r=C.intersects(t,e,n),s=C.intersects(t,e,i),o=C.intersects(n,i,t),a=C.intersects(n,i,e);return r&&s?(this.intPt[0]=n,this.intPt[1]=i,oe.COLLINEAR_INTERSECTION):o&&a?(this.intPt[0]=t,this.intPt[1]=e,oe.COLLINEAR_INTERSECTION):r&&o?(this.intPt[0]=n,this.intPt[1]=t,!n.equals(t)||s||a?oe.COLLINEAR_INTERSECTION:oe.POINT_INTERSECTION):r&&a?(this.intPt[0]=n,this.intPt[1]=e,!n.equals(e)||s||o?oe.COLLINEAR_INTERSECTION:oe.POINT_INTERSECTION):s&&o?(this.intPt[0]=i,this.intPt[1]=t,!i.equals(t)||r||a?oe.COLLINEAR_INTERSECTION:oe.POINT_INTERSECTION):s&&a?(this.intPt[0]=i,this.intPt[1]=e,!i.equals(e)||r||o?oe.COLLINEAR_INTERSECTION:oe.POINT_INTERSECTION):oe.NO_INTERSECTION},normalizeToEnvCentre:function(t,e,n,i,r){var s=t.xe.x?t.x:e.x,u=t.y>e.y?t.y:e.y,l=n.xi.x?n.x:i.x,f=n.y>i.y?n.y:i.y,g=s>l?s:l,d=ah?o:h,v=u0&&s>0||r<0&&s<0)return oe.NO_INTERSECTION;var o=he.orientationIndex(n,i,t),a=he.orientationIndex(n,i,e);if(o>0&&a>0||o<0&&a<0)return oe.NO_INTERSECTION;var u=0===r&&0===s&&0===o&&0===a;return u?this.computeCollinearIntersection(t,e,n,i):(0===r||0===s||0===o||0===a?(this._isProper=!1,t.equals2D(n)||t.equals2D(i)?this.intPt[0]=t:e.equals2D(n)||e.equals2D(i)?this.intPt[0]=e:0===r?this.intPt[0]=new g(n):0===s?this.intPt[0]=new g(i):0===o?this.intPt[0]=new g(t):0===a&&(this.intPt[0]=new g(e))):(this._isProper=!0,this.intPt[0]=this.intersection(t,e,n,i)),oe.POINT_INTERSECTION)},interfaces_:function(){return[]},getClass:function(){return ae}}),ae.nearestEndpoint=function(t,e,n,i){var r=t,s=he.distancePointLine(t,n,i),o=he.distancePointLine(e,n,i);return o0?n>0?-r:r:n>0?r:-r;if(0===e||0===n)return i>0?t>0?r:-r:t>0?-r:r;if(0=i?(t=-t,e=-e,n=-n,i=-i):(r=-r,s=-t,t=-n,n=s,s=-e,e=-i,i=s),0=n))return-r;r=-r,t=-t,n=-n}for(;;){if(a+=1,o=Math.floor(n/t),n-=o*t,i-=o*e,i<0)return-r;if(i>e)return r;if(t>n+n){if(ei+i)return-r;n=t-n,i=e-i,r=-r}if(0===i)return 0===n?0:-r;if(0===n)return r;if(o=Math.floor(t/n),t-=o*n,e-=o*i,e<0)return r;if(e>i)return-r;if(n>t+t){if(ie+e)return r;t=n-t,e=i-e,r=-r}if(0===e)return 0===t?0:r;if(0===t)return-r}},e(le.prototype,{countSegment:function(t,e){if(t.xi&&(n=e.x,i=t.x),this.p.x>=n&&this.p.x<=i&&(this.isPointOnSegment=!0),null}if(t.y>this.p.y&&e.y<=this.p.y||e.y>this.p.y&&t.y<=this.p.y){var r=t.x-this.p.x,s=t.y-this.p.y,o=e.x-this.p.x,a=e.y-this.p.y,u=ue.signOfDet2x2(r,s,o,a);if(0===u)return this.isPointOnSegment=!0,null;a0&&this.crossingCount++}},isPointInPolygon:function(){return this.getLocation()!==L.EXTERIOR},getLocation:function(){return this.isPointOnSegment?L.BOUNDARY:this.crossingCount%2===1?L.INTERIOR:L.EXTERIOR},isOnSegment:function(){return this.isPointOnSegment},interfaces_:function(){return[]},getClass:function(){return le}}),le.locatePointInRing=function(){if(arguments[0]instanceof g&&R(arguments[1],D)){for(var t=arguments[0],e=arguments[1],n=new le(t),i=new g,r=new g,s=1;s1||u<0||u>1)&&(r=!0)}}else r=!0;return r?T.min(he.distancePointLine(t,n,i),he.distancePointLine(e,n,i),he.distancePointLine(n,t,e),he.distancePointLine(i,t,e)):0},he.isPointInRing=function(t,e){return he.locatePointInRing(t,e)!==L.EXTERIOR},he.computeLength=function(t){var e=t.size();if(e<=1)return 0;var n=0,i=new g;t.getCoordinate(0,i);for(var r=i.x,s=i.y,o=1;on.y&&(n=o,r=s)}var a=r;do a-=1,a<0&&(a=e);while(t[a].equals2D(n)&&a!==r);var u=r;do u=(u+1)%e;while(t[u].equals2D(n)&&u!==r);var l=t[a],h=t[u];if(l.equals2D(n)||h.equals2D(n)||l.equals2D(h))return!1;var c=he.computeOrientation(l,n,h),f=!1;return f=0===c?l.x>h.x:c>0},he.locatePointInRing=function(t,e){return le.locatePointInRing(t,e)},he.distancePointLinePerpendicular=function(t,e,n){var i=(n.x-e.x)*(n.x-e.x)+(n.y-e.y)*(n.y-e.y),r=((e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y))/i;return Math.abs(r)*Math.sqrt(i)},he.computeOrientation=function(t,e,n){return he.orientationIndex(t,e,n)},he.distancePointLine=function(){if(2===arguments.length){var t=arguments[0],e=arguments[1];if(0===e.length)throw new i(\"Line array must contain at least one vertex\");for(var n=t.distance(e[0]),r=0;r=1)return o.distance(u);var c=((a.y-o.y)*(u.x-a.x)-(a.x-o.x)*(u.y-a.y))/l;return Math.abs(c)*Math.sqrt(l)}},he.isOnLine=function(t,e){for(var n=new ae,i=1;i=0&&n>=0?Math.max(e,n):e<=0&&n<=0?Math.max(e,n):0}if(arguments[0]instanceof g){var i=arguments[0];return he.orientationIndex(this.p0,this.p1,i)}},toGeometry:function(t){return t.createLineString([this.p0,this.p1])},isVertical:function(){return this.p0.x===this.p1.x},equals:function(t){if(!(t instanceof ce))return!1;var e=t;return this.p0.equals(e.p0)&&this.p1.equals(e.p1)},intersection:function(t){var e=new ae;return e.computeIntersection(this.p0,this.p1,t.p0,t.p1),e.hasIntersection()?e.getIntersection(0):null},project:function(){if(arguments[0]instanceof g){var t=arguments[0];if(t.equals(this.p0)||t.equals(this.p1))return new g(t);var e=this.projectionFactor(t),n=new g;return n.x=this.p0.x+e*(this.p1.x-this.p0.x),n.y=this.p0.y+e*(this.p1.y-this.p0.y),n}if(arguments[0]instanceof ce){var i=arguments[0],r=this.projectionFactor(i.p0),s=this.projectionFactor(i.p1);if(r>=1&&s>=1)return null;if(r<=0&&s<=0)return null;var o=this.project(i.p0);r<0&&(o=this.p0),r>1&&(o=this.p1);var a=this.project(i.p1);return s<0&&(a=this.p0),s>1&&(a=this.p1),new ce(o,a)}},normalize:function(){this.p1.compareTo(this.p0)<0&&this.reverse()},angle:function(){return Math.atan2(this.p1.y-this.p0.y,this.p1.x-this.p0.x)},getCoordinate:function(t){return 0===t?this.p0:this.p1},distancePerpendicular:function(t){return he.distancePointLinePerpendicular(t,this.p0,this.p1)},minY:function(){return Math.min(this.p0.y,this.p1.y)},midPoint:function(){return ce.midPoint(this.p0,this.p1)},projectionFactor:function(t){if(t.equals(this.p0))return 0;if(t.equals(this.p1))return 1;var e=this.p1.x-this.p0.x,n=this.p1.y-this.p0.y,i=e*e+n*n;if(i<=0)return r.NaN;var s=((t.x-this.p0.x)*e+(t.y-this.p0.y)*n)/i;return s},closestPoints:function(t){var e=this.intersection(t);if(null!==e)return[e,e];var n=new Array(2).fill(null),i=r.MAX_VALUE,s=null,o=this.closestPoint(t.p0);i=o.distance(t.p0),n[0]=o,n[1]=t.p0;var a=this.closestPoint(t.p1);s=a.distance(t.p1),s0&&e<1)return this.project(t);var n=this.p0.distance(t),i=this.p1.distance(t);return n1||r.isNaN(e))&&(e=1),e},toString:function(){return\"LINESTRING( \"+this.p0.x+\" \"+this.p0.y+\", \"+this.p1.x+\" \"+this.p1.y+\")\"},isHorizontal:function(){return this.p0.y===this.p1.y},distance:function(){if(arguments[0]instanceof ce){var t=arguments[0];return he.distanceLineLine(this.p0,this.p1,t.p0,t.p1)}if(arguments[0]instanceof g){var e=arguments[0];return he.distancePointLine(e,this.p0,this.p1)}},pointAlong:function(t){var e=new g;return e.x=this.p0.x+t*(this.p1.x-this.p0.x),e.y=this.p0.y+t*(this.p1.y-this.p0.y),e},hashCode:function(){var t=java.lang.Double.doubleToLongBits(this.p0.x);t^=31*java.lang.Double.doubleToLongBits(this.p0.y);var e=Math.trunc(t)^Math.trunc(t>>32),n=java.lang.Double.doubleToLongBits(this.p1.x);n^=31*java.lang.Double.doubleToLongBits(this.p1.y);var i=Math.trunc(n)^Math.trunc(n>>32);return e^i},interfaces_:function(){return[s,u]},getClass:function(){return ce}}),ce.midPoint=function(t,e){return new g((t.x+e.x)/2,(t.y+e.y)/2)},ce.serialVersionUID=0x2d2172135f411c00,e(fe.prototype,{isIntersects:function(){return!this.isDisjoint()},isCovers:function(){var t=fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])||fe.isTrue(this.matrix[L.INTERIOR][L.BOUNDARY])||fe.isTrue(this.matrix[L.BOUNDARY][L.INTERIOR])||fe.isTrue(this.matrix[L.BOUNDARY][L.BOUNDARY]);return t&&this.matrix[L.EXTERIOR][L.INTERIOR]===lt.FALSE&&this.matrix[L.EXTERIOR][L.BOUNDARY]===lt.FALSE},isCoveredBy:function(){var t=fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])||fe.isTrue(this.matrix[L.INTERIOR][L.BOUNDARY])||fe.isTrue(this.matrix[L.BOUNDARY][L.INTERIOR])||fe.isTrue(this.matrix[L.BOUNDARY][L.BOUNDARY]);return t&&this.matrix[L.INTERIOR][L.EXTERIOR]===lt.FALSE&&this.matrix[L.BOUNDARY][L.EXTERIOR]===lt.FALSE},set:function(){if(1===arguments.length)for(var t=arguments[0],e=0;e=0&&e>=0&&this.setAtLeast(t,e,n)},isWithin:function(){return fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])&&this.matrix[L.INTERIOR][L.EXTERIOR]===lt.FALSE&&this.matrix[L.BOUNDARY][L.EXTERIOR]===lt.FALSE},isTouches:function(t,e){return t>e?this.isTouches(e,t):(t===lt.A&&e===lt.A||t===lt.L&&e===lt.L||t===lt.L&&e===lt.A||t===lt.P&&e===lt.A||t===lt.P&&e===lt.L)&&(this.matrix[L.INTERIOR][L.INTERIOR]===lt.FALSE&&(fe.isTrue(this.matrix[L.INTERIOR][L.BOUNDARY])||fe.isTrue(this.matrix[L.BOUNDARY][L.INTERIOR])||fe.isTrue(this.matrix[L.BOUNDARY][L.BOUNDARY])))},isOverlaps:function(t,e){return t===lt.P&&e===lt.P||t===lt.A&&e===lt.A?fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])&&fe.isTrue(this.matrix[L.INTERIOR][L.EXTERIOR])&&fe.isTrue(this.matrix[L.EXTERIOR][L.INTERIOR]):t===lt.L&&e===lt.L&&(1===this.matrix[L.INTERIOR][L.INTERIOR]&&fe.isTrue(this.matrix[L.INTERIOR][L.EXTERIOR])&&fe.isTrue(this.matrix[L.EXTERIOR][L.INTERIOR]))},isEquals:function(t,e){return t===e&&(fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])&&this.matrix[L.INTERIOR][L.EXTERIOR]===lt.FALSE&&this.matrix[L.BOUNDARY][L.EXTERIOR]===lt.FALSE&&this.matrix[L.EXTERIOR][L.INTERIOR]===lt.FALSE&&this.matrix[L.EXTERIOR][L.BOUNDARY]===lt.FALSE)},toString:function(){for(var t=new P(\"123456789\"),e=0;e<3;e++)for(var n=0;n<3;n++)t.setCharAt(3*e+n,lt.toDimensionSymbol(this.matrix[e][n]));return t.toString()},setAll:function(t){for(var e=0;e<3;e++)for(var n=0;n<3;n++)this.matrix[e][n]=t},get:function(t,e){return this.matrix[t][e]},transpose:function(){var t=this.matrix[1][0];return this.matrix[1][0]=this.matrix[0][1],this.matrix[0][1]=t,t=this.matrix[2][0],this.matrix[2][0]=this.matrix[0][2],this.matrix[0][2]=t,t=this.matrix[2][1],this.matrix[2][1]=this.matrix[1][2],this.matrix[1][2]=t,this},matches:function(t){if(9!==t.length)throw new i(\"Should be length 9: \"+t);for(var e=0;e<3;e++)for(var n=0;n<3;n++)if(!fe.matches(this.matrix[e][n],t.charAt(3*e+n)))return!1;return!0},add:function(t){for(var e=0;e<3;e++)for(var n=0;n<3;n++)this.setAtLeast(e,n,t.get(e,n))},isDisjoint:function(){return this.matrix[L.INTERIOR][L.INTERIOR]===lt.FALSE&&this.matrix[L.INTERIOR][L.BOUNDARY]===lt.FALSE&&this.matrix[L.BOUNDARY][L.INTERIOR]===lt.FALSE&&this.matrix[L.BOUNDARY][L.BOUNDARY]===lt.FALSE},isCrosses:function(t,e){return t===lt.P&&e===lt.L||t===lt.P&&e===lt.A||t===lt.L&&e===lt.A?fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])&&fe.isTrue(this.matrix[L.INTERIOR][L.EXTERIOR]):t===lt.L&&e===lt.P||t===lt.A&&e===lt.P||t===lt.A&&e===lt.L?fe.isTrue(this.matrix[L.INTERIOR][L.INTERIOR])&&fe.isTrue(this.matrix[L.EXTERIOR][L.INTERIOR]):t===lt.L&&e===lt.L&&0===this.matrix[L.INTERIOR][L.INTERIOR]},interfaces_:function(){return[o]},getClass:function(){return fe}}),fe.matches=function(){if(Number.isInteger(arguments[0])&&\"string\"==typeof arguments[1]){var t=arguments[0],e=arguments[1];return e===lt.SYM_DONTCARE||(e===lt.SYM_TRUE&&(t>=0||t===lt.TRUE)||(e===lt.SYM_FALSE&&t===lt.FALSE||(e===lt.SYM_P&&t===lt.P||(e===lt.SYM_L&&t===lt.L||e===lt.SYM_A&&t===lt.A))))}if(\"string\"==typeof arguments[0]&&\"string\"==typeof arguments[1]){var n=arguments[0],i=arguments[1],r=new fe(n);return r.matches(i)}},fe.isTrue=function(t){return t>=0||t===lt.TRUE};var lo=Object.freeze({Coordinate:g,CoordinateList:N,Envelope:C,LineSegment:ce,GeometryFactory:ie,Geometry:B,Point:Lt,LineString:St,LinearRing:bt,Polygon:Tt,GeometryCollection:ft,MultiPoint:Pt,MultiLineString:gt,MultiPolygon:Ot,Dimension:lt,IntersectionMatrix:fe,PrecisionModel:ee});e(ge.prototype,{addPoint:function(t){this.ptCount+=1,this.ptCentSum.x+=t.x,this.ptCentSum.y+=t.y},setBasePoint:function(t){null===this.areaBasePt&&(this.areaBasePt=t)},addLineSegments:function(t){for(var e=0,n=0;n0&&this.addPoint(t[0])},addHole:function(t){for(var e=he.isCCW(t),n=0;n0)t.x=this.cg3.x/3/this.areasum2,t.y=this.cg3.y/3/this.areasum2;else if(this.totalLength>0)t.x=this.lineCentSum.x/this.totalLength,t.y=this.lineCentSum.y/this.totalLength;else{if(!(this.ptCount>0))return null;t.x=this.ptCentSum.x/this.ptCount,t.y=this.ptCentSum.y/this.ptCount}return t},addShell:function(t){t.length>0&&this.setBasePoint(t[0]);for(var e=!he.isCCW(t),n=0;n=this.size())throw new IndexOutOfBoundsException;return this.array_[t]},pe.prototype.push=function(t){return this.array_.push(t),t},pe.prototype.pop=function(t){if(0===this.array_.length)throw new de;return this.array_.pop()},pe.prototype.peek=function(){if(0===this.array_.length)throw new de;return this.array_[this.array_.length-1]},pe.prototype.empty=function(){return 0===this.array_.length},pe.prototype.isEmpty=function(){return this.empty()},pe.prototype.search=function(t){return this.array_.indexOf(t)},pe.prototype.size=function(){return this.array_.length},pe.prototype.toArray=function(){for(var t=[],e=0,n=this.array_.length;e50&&(t=this.reduce(this.inputPts));var e=this.preSort(t),n=this.grahamScan(e),i=this.toCoordinateArray(n);return this.lineOrPolygon(i)},padArray3:function(t){for(var e=new Array(3).fill(null),n=0;ne[2].y&&(e[2]=t[i]),t[i].x+t[i].y>e[3].x+e[3].y&&(e[3]=t[i]),t[i].x>e[4].x&&(e[4]=t[i]),t[i].x-t[i].y>e[5].x-e[5].y&&(e[5]=t[i]),t[i].y0;)e=n.pop();e=n.push(e),e=n.push(t[i]);\n}return e=n.push(t[0]),n},interfaces_:function(){return[]},getClass:function(){return me}}),me.extractCoordinates=function(t){var e=new ve;return t.apply(e),e.getCoordinates()},e(ye.prototype,{compare:function(t,e){var n=t,i=e;return ye.polarCompare(this.origin,n,i)},interfaces_:function(){return[a]},getClass:function(){return ye}}),ye.polarCompare=function(t,e,n){var i=e.x-t.x,r=e.y-t.y,s=n.x-t.x,o=n.y-t.y,a=he.computeOrientation(t,e,n);if(a===he.COUNTERCLOCKWISE)return 1;if(a===he.CLOCKWISE)return-1;var u=i*i+r*r,l=s*s+o*o;return ul?1:0},me.RadialComparator=ye,e(xe.prototype,{transformPoint:function(t,e){return this.factory.createPoint(this.transformCoordinates(t.getCoordinateSequence(),t))},transformPolygon:function(t,e){var n=!0,i=this.transformLinearRing(t.getExteriorRing(),t);null!==i&&i instanceof bt&&!i.isEmpty()||(n=!1);for(var r=new I,s=0;s0&&i<4&&!this.preserveType?this.factory.createLineString(n):this.factory.createLinearRing(n)},interfaces_:function(){return[]},getClass:function(){return xe}}),e(Ee.prototype,{snapVertices:function(t,e){for(var n=this._isClosed?t.size()-1:t.size(),i=0;i=0&&t.add(s+1,new g(r),!1)}},findSegmentIndexToSnap:function(t,e){for(var n=r.MAX_VALUE,i=-1,s=0;se&&(e=i)}return e}if(2===arguments.length){var r=arguments[0],s=arguments[1];return Math.min(Ie.computeOverlaySnapTolerance(r),Ie.computeOverlaySnapTolerance(s))}},Ie.computeSizeBasedSnapTolerance=function(t){var e=t.getEnvelopeInternal(),n=Math.min(e.getHeight(),e.getWidth()),i=n*Ie.SNAP_PRECISION_FACTOR;return i},Ie.snapToSelf=function(t,e,n){var i=new Ie(t);return i.snapToSelf(e,n)},Ie.SNAP_PRECISION_FACTOR=1e-9,h(Ne,xe),e(Ne.prototype,{snapLine:function(t,e){var n=new Ee(t,this.snapTolerance);return n.setAllowSnappingToSourceVertices(this.isSelfSnap),n.snapTo(e)},transformCoordinates:function(t,e){var n=t.toCoordinateArray(),i=this.snapLine(n,this.snapPts);return this.factory.getCoordinateSequenceFactory().create(i)},interfaces_:function(){return[]},getClass:function(){return Ne}}),e(Ce.prototype,{getCommon:function(){return r.longBitsToDouble(this.commonBits)},add:function(t){var e=r.doubleToLongBits(t);if(this.isFirst)return this.commonBits=e,this.commonSignExp=Ce.signExpBits(this.commonBits),this.isFirst=!1,null;var n=Ce.signExpBits(e);return n!==this.commonSignExp?(this.commonBits=0,null):(this.commonMantissaBitsCount=Ce.numCommonMostSigMantissaBits(this.commonBits,e),void(this.commonBits=Ce.zeroLowerBits(this.commonBits,64-(12+this.commonMantissaBitsCount))))},toString:function(){if(1===arguments.length){var t=arguments[0],e=r.longBitsToDouble(t),n=Long.toBinaryString(t),i=\"0000000000000000000000000000000000000000000000000000000000000000\"+n,s=i.substring(i.length-64),o=s.substring(0,1)+\" \"+s.substring(1,12)+\"(exp) \"+s.substring(12)+\" [ \"+e+\" ]\";return o}},interfaces_:function(){return[]},getClass:function(){return Ce}}),Ce.getBit=function(t,e){var n=1<>52},Ce.zeroLowerBits=function(t,e){var n=(1<=0;i--){if(Ce.getBit(t,i)!==Ce.getBit(e,i))return n;n++}return 52},e(Se.prototype,{addCommonBits:function(t){var e=new Le(this.commonCoord);t.apply(e),t.geometryChanged()},removeCommonBits:function(t){if(0===this.commonCoord.x&&0===this.commonCoord.y)return t;var e=new g(this.commonCoord);e.x=-e.x,e.y=-e.y;var n=new Le(e);return t.apply(n),t.geometryChanged(),t},getCommonCoordinate:function(){return this.commonCoord},add:function(t){t.apply(this.ccFilter),this.commonCoord=this.ccFilter.getCommonCoordinate()},interfaces_:function(){return[]},getClass:function(){return Se}}),e(we.prototype,{filter:function(t){this.commonBitsX.add(t.x),this.commonBitsY.add(t.y)},getCommonCoordinate:function(){return new g(this.commonBitsX.getCommon(),this.commonBitsY.getCommon())},interfaces_:function(){return[z]},getClass:function(){return we}}),e(Le.prototype,{filter:function(t,e){var n=t.getOrdinate(e,0)+this.trans.x,i=t.getOrdinate(e,1)+this.trans.y;t.setOrdinate(e,0,n),t.setOrdinate(e,1,i)},isDone:function(){return!1},isGeometryChanged:function(){return!0},interfaces_:function(){return[ct]},getClass:function(){return Le}}),Se.CommonCoordinateFilter=we,Se.Translater=Le,e(Re.prototype,{next:function(){if(this.atStart)return this.atStart=!1,Re.isAtomic(this.parent)&&this.index++,this.parent;if(null!==this.subcollectionIterator){if(this.subcollectionIterator.hasNext())return this.subcollectionIterator.next();this.subcollectionIterator=null}if(this.index>=this.max)throw new x;var t=this.parent.getGeometryN(this.index++);return t instanceof ft?(this.subcollectionIterator=new Re(t),this.subcollectionIterator.next()):t},remove:function(){throw new UnsupportedOperationException(this.getClass().getName())},hasNext:function(){if(this.atStart)return!0;if(null!==this.subcollectionIterator){if(this.subcollectionIterator.hasNext())return!0;this.subcollectionIterator=null}return!(this.index>=this.max)},interfaces_:function(){return[p]},getClass:function(){return Re}}),Re.isAtomic=function(t){return!(t instanceof ft)},e(Te.prototype,{locateInternal:function(){if(arguments[0]instanceof g&&arguments[1]instanceof Tt){var t=arguments[0],e=arguments[1];if(e.isEmpty())return L.EXTERIOR;var n=e.getExteriorRing(),i=this.locateInPolygonRing(t,n);if(i===L.EXTERIOR)return L.EXTERIOR;if(i===L.BOUNDARY)return L.BOUNDARY;for(var r=0;r0||this.isIn?L.INTERIOR:L.EXTERIOR)},interfaces_:function(){return[]},getClass:function(){return Te}}),e(Pe.prototype,{interfaces_:function(){return[]},getClass:function(){return Pe}}),Pe.octant=function(){if(\"number\"==typeof arguments[0]&&\"number\"==typeof arguments[1]){var t=arguments[0],e=arguments[1];if(0===t&&0===e)throw new i(\"Cannot compute the octant for point ( \"+t+\", \"+e+\" )\");var n=Math.abs(t),r=Math.abs(e);return t>=0?e>=0?n>=r?0:1:n>=r?7:6:e>=0?n>=r?3:2:n>=r?4:5}if(arguments[0]instanceof g&&arguments[1]instanceof g){var s=arguments[0],o=arguments[1],a=o.x-s.x,u=o.y-s.y;if(0===a&&0===u)throw new i(\"Cannot compute the octant for two identical points \"+s);return Pe.octant(a,u)}},e(be.prototype,{getCoordinates:function(){},size:function(){},getCoordinate:function(t){},isClosed:function(){},setData:function(t){},getData:function(){},interfaces_:function(){return[]},getClass:function(){return be}}),e(Oe.prototype,{getCoordinates:function(){return this.pts},size:function(){return this.pts.length},getCoordinate:function(t){return this.pts[t]},isClosed:function(){return this.pts[0].equals(this.pts[this.pts.length-1])},getSegmentOctant:function(t){return t===this.pts.length-1?-1:Pe.octant(this.getCoordinate(t),this.getCoordinate(t+1))},setData:function(t){this.data=t},getData:function(){return this.data},toString:function(){return se.toLineString(new Gt(this.pts))},interfaces_:function(){return[be]},getClass:function(){return Oe}}),e(_e.prototype,{getBounds:function(){},interfaces_:function(){return[]},getClass:function(){return _e}}),e(Me.prototype,{getItem:function(){return this.item},getBounds:function(){return this.bounds},interfaces_:function(){return[_e,u]},getClass:function(){return Me}}),e(De.prototype,{poll:function(){if(this.isEmpty())return null;var t=this.items.get(1);return this.items.set(1,this.items.get(this._size)),this._size-=1,this.reorder(1),t},size:function(){return this._size},reorder:function(t){for(var e=null,n=this.items.get(t);2*t<=this._size&&(e=2*t,e!==this._size&&this.items.get(e+1).compareTo(this.items.get(e))<0&&e++,this.items.get(e).compareTo(n)<0);t=e)this.items.set(t,this.items.get(e));this.items.set(t,n)},clear:function(){this._size=0,this.items.clear()},isEmpty:function(){return 0===this._size},add:function(t){this.items.add(null),this._size+=1;var e=this._size;for(this.items.set(0,t);t.compareTo(this.items.get(Math.trunc(e/2)))<0;e/=2)this.items.set(e,this.items.get(Math.trunc(e/2)));this.items.set(e,t)},interfaces_:function(){return[]},getClass:function(){return De}}),e(Ae.prototype,{visitItem:function(t){},interfaces_:function(){return[]},getClass:function(){return Ae}}),e(Fe.prototype,{insert:function(t,e){},remove:function(t,e){},query:function(){if(1===arguments.length){arguments[0]}else if(2===arguments.length){arguments[0],arguments[1]}},interfaces_:function(){return[]},getClass:function(){return Fe}}),e(Ge.prototype,{getLevel:function(){return this.level},size:function(){return this.childBoundables.size()},getChildBoundables:function(){return this.childBoundables},addChildBoundable:function(t){f.isTrue(null===this.bounds),this.childBoundables.add(t)},isEmpty:function(){return this.childBoundables.isEmpty()},getBounds:function(){return null===this.bounds&&(this.bounds=this.computeBounds()),this.bounds},interfaces_:function(){return[_e,u]},getClass:function(){return Ge}}),Ge.serialVersionUID=0x5a1e55ec41369800;var ho={reverseOrder:function(){return{compare:function(t,e){return e.compareTo(t)}}},min:function(t){return ho.sort(t),t.get(0)},sort:function(t,e){var n=t.toArray();e?ut.sort(n,e):ut.sort(n);for(var i=t.iterator(),r=0,s=n.length;rqe.area(this.boundable2)?(this.expand(this.boundable1,this.boundable2,t,e),null):(this.expand(this.boundable2,this.boundable1,t,e),null);if(n)return this.expand(this.boundable1,this.boundable2,t,e),null;if(r)return this.expand(this.boundable2,this.boundable1,t,e),null;throw new i(\"neither boundable is composite\")},isLeaves:function(){return!(qe.isComposite(this.boundable1)||qe.isComposite(this.boundable2))},compareTo:function(t){var e=t;return this._distancee._distance?1:0},expand:function(t,e,n,i){for(var r=t.getChildBoundables(),s=r.iterator();s.hasNext();){var o=s.next(),a=new qe(o,e,this.itemDistance);a.getDistance()-2),i.getLevel()===n)return r.add(i),null;for(var s=i.getChildBoundables().iterator();s.hasNext();){var o=s.next();o instanceof Ge?this.boundablesAtLevel(n,o,r):(f.isTrue(o instanceof Me),n===-1&&r.add(o))}return null}},query:function(){if(1===arguments.length){var t=arguments[0];this.build();var e=new I;return this.isEmpty()?e:(this.getIntersectsOp().intersects(this.root.getBounds(),t)&&this.query(t,this.root,e),e)}if(2===arguments.length){var n=arguments[0],i=arguments[1];if(this.build(),this.isEmpty())return null;this.getIntersectsOp().intersects(this.root.getBounds(),n)&&this.query(n,this.root,i)}else if(3===arguments.length)if(R(arguments[2],Ae)&&arguments[0]instanceof Object&&arguments[1]instanceof Ge)for(var r=arguments[0],s=arguments[1],o=arguments[2],a=s.getChildBoundables(),u=0;ue&&(e=r)}}return e+1}},createParentBoundables:function(t,e){f.isTrue(!t.isEmpty());var n=new I;n.add(this.createNode(e));var i=new I(t);ho.sort(i,this.getComparator());for(var r=i.iterator();r.hasNext();){var s=r.next();this.lastNode(n).getChildBoundables().size()===this.getNodeCapacity()&&n.add(this.createNode(e)),this.lastNode(n).addChildBoundable(s)}return n},isEmpty:function(){return this.built?this.root.isEmpty():this.itemBoundables.isEmpty()},interfaces_:function(){return[u]},getClass:function(){return Be}}),Be.compareDoubles=function(t,e){return t>e?1:t0);for(var n=new I,i=0;i0;){var c=h.poll(),f=c.getDistance();if(f>=u)break;c.isLeaves()?(u=f,l=c):c.expandToQueue(h,u)}return[l.getBoundable(0).getItem(),l.getBoundable(1).getItem()]}}else if(3===arguments.length){var g=arguments[0],d=arguments[1],p=arguments[2],v=new Me(g,d),e=new qe(this.getRoot(),v,p);return this.nearestNeighbour(e)[0]}},interfaces_:function(){return[Fe,u]},getClass:function(){return ke}}),ke.centreX=function(t){return ke.avg(t.getMinX(),t.getMaxX())},ke.avg=function(t,e){return(t+e)/2},ke.centreY=function(t){return ke.avg(t.getMinY(),t.getMaxY())},h(Ye,Ge),e(Ye.prototype,{computeBounds:function(){for(var t=null,e=this.getChildBoundables().iterator();e.hasNext();){var n=e.next();null===t?t=new C(n.getBounds()):t.expandToInclude(n.getBounds())}return t},interfaces_:function(){return[]},getClass:function(){return Ye}}),ke.STRtreeNode=Ye,ke.serialVersionUID=0x39920f7d5f261e0,ke.xComparator={interfaces_:function(){return[a]},compare:function(t,e){return Be.compareDoubles(ke.centreX(t.getBounds()),ke.centreX(e.getBounds()))}},ke.yComparator={interfaces_:function(){return[a]},compare:function(t,e){return Be.compareDoubles(ke.centreY(t.getBounds()),ke.centreY(e.getBounds()))}},ke.intersectsOp={interfaces_:function(){return[IntersectsOp]},intersects:function(t,e){return t.intersects(e)}},ke.DEFAULT_NODE_CAPACITY=10,e(Ue.prototype,{interfaces_:function(){return[]},getClass:function(){return Ue}}),Ue.relativeSign=function(t,e){return te?1:0},Ue.compare=function(t,e,n){if(e.equals2D(n))return 0;var i=Ue.relativeSign(e.x,n.x),r=Ue.relativeSign(e.y,n.y);switch(t){case 0:return Ue.compareValue(i,r);case 1:return Ue.compareValue(r,i);case 2:return Ue.compareValue(r,-i);case 3:return Ue.compareValue(-i,r);case 4:return Ue.compareValue(-i,-r);case 5:return Ue.compareValue(-r,-i);case 6:return Ue.compareValue(-r,i);case 7:return Ue.compareValue(i,-r)}return f.shouldNeverReachHere(\"invalid octant value\"),0},Ue.compareValue=function(t,e){return t<0?-1:t>0?1:e<0?-1:e>0?1:0},e(Xe.prototype,{getCoordinate:function(){return this.coord},print:function(t){t.print(this.coord),t.print(\" seg # = \"+this.segmentIndex)},compareTo:function(t){var e=t;return this.segmentIndexe.segmentIndex?1:this.coord.equals2D(e.coord)?0:Ue.compare(this.segmentOctant,this.coord,e.coord)},isEndPoint:function(t){return 0===this.segmentIndex&&!this._isInterior||this.segmentIndex===t},isInterior:function(){return this._isInterior},interfaces_:function(){return[s]},getClass:function(){return Xe}}),e(He.prototype,{getSplitCoordinates:function(){var t=new N;this.addEndpoints();for(var e=this.iterator(),n=e.next();e.hasNext();){var i=e.next();this.addEdgeCoordinates(n,i,t),n=i}return t.toCoordinateArray()},addCollapsedNodes:function(){var t=new I;this.findCollapsesFromInsertedNodes(t),this.findCollapsesFromExistingVertices(t);for(var e=t.iterator();e.hasNext();){var n=e.next().intValue();this.add(this.edge.getCoordinate(n),n)}},print:function(t){t.println(\"Intersections:\");for(var e=this.iterator();e.hasNext();){var n=e.next();n.print(t)}},findCollapsesFromExistingVertices:function(t){for(var e=0;ethis.currNode.segmentIndex,null)},remove:function(){throw new UnsupportedOperationException(this.getClass().getName())},hasNext:function(){return null!==this.nextNode},readNextNode:function(){this.nodeIt.hasNext()?this.nextNode=this.nodeIt.next():this.nextNode=null},interfaces_:function(){return[p]},getClass:function(){return We}}),e(je.prototype,{addIntersection:function(t,e){},interfaces_:function(){return[be]},getClass:function(){return je}}),e(Ke.prototype,{getCoordinates:function(){return this.pts},size:function(){return this.pts.length},getCoordinate:function(t){return this.pts[t]},isClosed:function(){return this.pts[0].equals(this.pts[this.pts.length-1])},getSegmentOctant:function(t){return t===this.pts.length-1?-1:this.safeOctant(this.getCoordinate(t),this.getCoordinate(t+1))},setData:function(t){this.data=t},safeOctant:function(t,e){return t.equals2D(e)?0:Pe.octant(t,e)},getData:function(){return this.data},addIntersection:function(){if(2===arguments.length){var t=arguments[0],e=arguments[1];this.addIntersectionNode(t,e)}else if(4===arguments.length){var n=arguments[0],i=arguments[1],r=(arguments[2],arguments[3]),s=new g(n.getIntersection(r));this.addIntersection(s,i)}},toString:function(){return se.toLineString(new Gt(this.pts))},getNodeList:function(){return this.nodeList},addIntersectionNode:function(t,e){var n=e,i=n+1;if(ie?t:e;return 0===i&&3===r?3:i},Je.isInHalfPlane=function(t,e){return e===Je.SE?t===Je.SE||t===Je.SW:t===e||t===e+1},Je.quadrant=function(){if(\"number\"==typeof arguments[0]&&\"number\"==typeof arguments[1]){var t=arguments[0],e=arguments[1];if(0===t&&0===e)throw new i(\"Cannot compute the quadrant for point ( \"+t+\", \"+e+\" )\");return t>=0?e>=0?Je.NE:Je.SE:e>=0?Je.NW:Je.SW}if(arguments[0]instanceof g&&arguments[1]instanceof g){var n=arguments[0],r=arguments[1];if(r.x===n.x&&r.y===n.y)throw new i(\"Cannot compute the quadrant for two identical points \"+n);return r.x>=n.x?r.y>=n.y?Je.NE:Je.SE:r.y>=n.y?Je.NW:Je.SW}},Je.NE=0,Je.NW=1,Je.SW=2,Je.SE=3,e($e.prototype,{interfaces_:function(){return[]},getClass:function(){return $e}}),$e.getChainStartIndices=function(t){var e=0,n=new I;n.add(new b(e));do{var i=$e.findChainEnd(t,e);n.add(new b(i)),e=i}while(e=t.length-1)return t.length-1;for(var i=Je.quadrant(t[n],t[n+1]),r=e+1;rn.getId()&&(n.computeOverlaps(s,t),this.nOverlaps++),this.segInt.isDone())return null}},interfaces_:function(){return[]},getClass:function(){return nn}}),h(rn,Ze),e(rn.prototype,{overlap:function(){if(4!==arguments.length)return Ze.prototype.overlap.apply(this,arguments);var t=arguments[0],e=arguments[1],n=arguments[2],i=arguments[3],r=t.getContext(),s=n.getContext();this.si.processIntersections(r,e,s,i)},interfaces_:function(){return[]},getClass:function(){return rn}}),nn.SegmentOverlapAction=rn,h(sn,l),e(sn.prototype,{getCoordinate:function(){return this.pt},interfaces_:function(){return[]},getClass:function(){return sn}}),sn.msgWithCoord=function(t,e){return null!==e?t+\" [ \"+e+\" ]\":t},e(on.prototype,{processIntersections:function(t,e,n,i){},isDone:function(){},interfaces_:function(){return[]},getClass:function(){return on}}),e(an.prototype,{getInteriorIntersection:function(){return this.interiorIntersection},setCheckEndSegmentsOnly:function(t){this.isCheckEndSegmentsOnly=t},getIntersectionSegments:function(){return this.intSegments},count:function(){return this.intersectionCount},getIntersections:function(){return this.intersections},setFindAllIntersections:function(t){this.findAllIntersections=t},setKeepIntersections:function(t){this.keepIntersections=t},processIntersections:function(t,e,n,i){if(!this.findAllIntersections&&this.hasIntersection())return null;if(t===n&&e===i)return null;if(this.isCheckEndSegmentsOnly){var r=this.isEndSegment(t,e)||this.isEndSegment(n,i);if(!r)return null}var s=t.getCoordinates()[e],o=t.getCoordinates()[e+1],a=n.getCoordinates()[i],u=n.getCoordinates()[i+1];this.li.computeIntersection(s,o,a,u),this.li.hasIntersection()&&this.li.isInteriorIntersection()&&(this.intSegments=new Array(4).fill(null),this.intSegments[0]=s,this.intSegments[1]=o,this.intSegments[2]=a,this.intSegments[3]=u,this.interiorIntersection=this.li.getIntersection(0),this.keepIntersections&&this.intersections.add(this.interiorIntersection),this.intersectionCount++)},isEndSegment:function(t,e){return 0===e||e>=t.size()-2},hasIntersection:function(){return null!==this.interiorIntersection},isDone:function(){return!this.findAllIntersections&&null!==this.interiorIntersection},interfaces_:function(){return[on]},getClass:function(){return an}}),an.createAllIntersectionsFinder=function(t){var e=new an(t);return e.setFindAllIntersections(!0),e},an.createAnyIntersectionFinder=function(t){return new an(t)},an.createIntersectionCounter=function(t){var e=new an(t);return e.setFindAllIntersections(!0),e.setKeepIntersections(!1),e},e(un.prototype,{execute:function(){return null!==this.segInt?null:void this.checkInteriorIntersections()},getIntersections:function(){return this.segInt.getIntersections()},isValid:function(){return this.execute(),this._isValid},setFindAllIntersections:function(t){this.findAllIntersections=t},checkInteriorIntersections:function(){this._isValid=!0,this.segInt=new an(this.li),this.segInt.setFindAllIntersections(this.findAllIntersections);var t=new nn;if(t.setSegmentIntersector(this.segInt),t.computeNodes(this.segStrings),this.segInt.hasIntersection())return this._isValid=!1,null},checkValid:function(){if(this.execute(),!this._isValid)throw new sn(this.getErrorMessage(),this.segInt.getInteriorIntersection())},getErrorMessage:function(){if(this._isValid)return\"no intersections found\";var t=this.segInt.getIntersectionSegments();return\"found non-noded intersection between \"+se.toLineString(t[0],t[1])+\" and \"+se.toLineString(t[2],t[3])},interfaces_:function(){return[]},getClass:function(){return un}}),un.computeIntersections=function(t){var e=new un(t);return e.setFindAllIntersections(!0),e.isValid(),e.getIntersections()},e(ln.prototype,{checkValid:function(){this.nv.checkValid()},interfaces_:function(){return[]},getClass:function(){return ln}}),ln.toSegmentStrings=function(t){for(var e=new I,n=t.iterator();n.hasNext();){var i=n.next();e.add(new Oe(i.getCoordinates(),i))}return e},ln.checkValid=function(t){var e=new ln(t);e.checkValid()},e(hn.prototype,{map:function(t){for(var e=new I,n=0;nthis.location.length){var e=new Array(3).fill(null);e[cn.ON]=this.location[cn.ON],e[cn.LEFT]=L.NONE,e[cn.RIGHT]=L.NONE,this.location=e}for(var n=0;n1&&t.append(L.toLocationSymbol(this.location[cn.LEFT])),t.append(L.toLocationSymbol(this.location[cn.ON])),this.location.length>1&&t.append(L.toLocationSymbol(this.location[cn.RIGHT])),t.toString()},setLocations:function(t,e,n){this.location[cn.ON]=t,this.location[cn.LEFT]=e,this.location[cn.RIGHT]=n},get:function(t){return t1},isAnyNull:function(){for(var t=0;tthis.maxNodeDegree&&(this.maxNodeDegree=n),t=this.getNext(t)}while(t!==this.startDe);this.maxNodeDegree*=2},addPoints:function(t,e,n){var i=t.getCoordinates();if(e){var r=1;n&&(r=0);for(var s=r;s=0;s--)this.pts.add(i[s])}},isHole:function(){return this._isHole},setInResult:function(){var t=this.startDe;do t.getEdge().setInResult(!0),t=t.getNext();while(t!==this.startDe)},containsPoint:function(t){var e=this.getLinearRing(),n=e.getEnvelopeInternal();if(!n.contains(t))return!1;if(!he.isPointInRing(t,e.getCoordinates()))return!1;for(var i=this.holes.iterator();i.hasNext();){var r=i.next();if(r.containsPoint(t))return!1}return!0},addHole:function(t){this.holes.add(t)},isShell:function(){return null===this.shell},getLabel:function(){return this.label},getEdges:function(){return this.edges},getMaxNodeDegree:function(){return this.maxNodeDegree<0&&this.computeMaxNodeDegree(),this.maxNodeDegree},getShell:function(){return this.shell},mergeLabel:function(){if(1===arguments.length){var t=arguments[0];this.mergeLabel(t,0),this.mergeLabel(t,1)}else if(2===arguments.length){var e=arguments[0],n=arguments[1],i=e.getLocation(n,cn.RIGHT);if(i===L.NONE)return null;if(this.label.getLocation(n)===L.NONE)return this.label.setLocation(n,i),null}},setShell:function(t){this.shell=t,null!==t&&t.addHole(this)},toPolygon:function(t){for(var e=new Array(this.holes.size()).fill(null),n=0;n=2,\"found partial label\"),this.computeIM(t)},isInResult:function(){return this._isInResult},isVisited:function(){return this._isVisited},interfaces_:function(){return[]},getClass:function(){return mn}}),h(yn,mn),e(yn.prototype,{isIncidentEdgeInResult:function(){for(var t=this.getEdges().getEdges().iterator();t.hasNext();){var e=t.next();if(e.getEdge().isInResult())return!0}return!1},isIsolated:function(){return 1===this.label.getGeometryCount()},getCoordinate:function(){return this.coord},print:function(t){t.println(\"node \"+this.coord+\" lbl: \"+this.label)},computeIM:function(t){},computeMergedLocation:function(t,e){var n=L.NONE;if(n=this.label.getLocation(e),!t.isNull(e)){var i=t.getLocation(e);n!==L.BOUNDARY&&(n=i)}return n},setLabel:function(){if(2!==arguments.length)return mn.prototype.setLabel.apply(this,arguments);var t=arguments[0],e=arguments[1];null===this.label?this.label=new gn(t,e):this.label.setLocation(t,e)},getEdges:function(){return this.edges},mergeLabel:function(){if(arguments[0]instanceof yn){var t=arguments[0];this.mergeLabel(t.label)}else if(arguments[0]instanceof gn)for(var e=arguments[0],n=0;n<2;n++){var i=this.computeMergedLocation(e,n),r=this.label.getLocation(n);r===L.NONE&&this.label.setLocation(n,i)}},add:function(t){this.edges.insert(t),t.setNode(this)},setLabelBoundary:function(t){if(null===this.label)return null;var e=L.NONE;null!==this.label&&(e=this.label.getLocation(t));var n=null;switch(e){case L.BOUNDARY:n=L.INTERIOR;break;case L.INTERIOR:n=L.BOUNDARY;break;default:n=L.BOUNDARY}this.label.setLocation(t,n)},interfaces_:function(){return[]},getClass:function(){return yn}}),e(xn.prototype,{find:function(t){return this.nodeMap.get(t)},addNode:function(){if(arguments[0]instanceof g){var t=arguments[0],e=this.nodeMap.get(t);return null===e&&(e=this.nodeFact.createNode(t),this.nodeMap.put(t,e)),e}if(arguments[0]instanceof yn){var n=arguments[0],e=this.nodeMap.get(n.getCoordinate());return null===e?(this.nodeMap.put(n.getCoordinate(),n),n):(e.mergeLabel(n),e)}},print:function(t){for(var e=this.iterator();e.hasNext();){var n=e.next();n.print(t)}},iterator:function(){return this.nodeMap.values().iterator()},values:function(){return this.nodeMap.values()},getBoundaryNodes:function(t){for(var e=new I,n=this.iterator();n.hasNext();){var i=n.next();i.getLabel().getLocation(t)===L.BOUNDARY&&e.add(i)}return e},add:function(t){var e=t.getCoordinate(),n=this.addNode(e);n.add(t)},interfaces_:function(){return[]},getClass:function(){return xn}}),e(En.prototype,{compareDirection:function(t){return this.dx===t.dx&&this.dy===t.dy?0:this.quadrant>t.quadrant?1:this.quadrant2){s.linkDirectedEdgesForMinimalEdgeRings();var o=s.buildMinimalRings(),a=this.findShell(o);null!==a?(this.placePolygonHoles(a,o),e.add(a)):n.addAll(o)}else i.add(s)}return i},containsPoint:function(t){for(var e=this.shellList.iterator();e.hasNext();){var n=e.next();if(n.containsPoint(t))return!0}return!1},buildMaximalEdgeRings:function(t){for(var e=new I,n=t.iterator();n.hasNext();){var i=n.next();if(i.isInResult()&&i.getLabel().isArea()&&null===i.getEdgeRing()){var r=new vn(i,this.geometryFactory);e.add(r),r.setInResult()}}return e},placePolygonHoles:function(t,e){for(var n=e.iterator();n.hasNext();){var i=n.next();i.isHole()&&i.setShell(t)}},getPolygons:function(){var t=this.computePolygons(this.shellList);return t},findEdgeRingContaining:function(t,e){for(var n=t.getLinearRing(),i=n.getEnvelopeInternal(),r=n.getCoordinateN(0),s=null,o=null,a=e.iterator();a.hasNext();){var u=a.next(),l=u.getLinearRing(),h=l.getEnvelopeInternal();null!==s&&(o=s.getLinearRing().getEnvelopeInternal());var c=!1;h.contains(i)&&he.isPointInRing(r,l.getCoordinates())&&(c=!0),c&&(null===s||o.contains(h))&&(s=u)}return s},findShell:function(t){for(var e=0,n=null,i=t.iterator();i.hasNext();){var r=i.next();r.isHole()||(n=r,e++)}return f.isTrue(e<=1,\"found two shells in MinimalEdgeRing list\"),n},add:function(){if(1===arguments.length){var t=arguments[0];this.add(t.getEdgeEnds(),t.getNodes())}else if(2===arguments.length){var e=arguments[0],n=arguments[1];Cn.linkResultDirectedEdges(n);var i=this.buildMaximalEdgeRings(e),r=new I,s=this.buildMinimalEdgeRings(i,this.shellList,r);this.sortShellsAndHoles(s,this.shellList,r),this.placeFreeHoles(this.shellList,r)}},interfaces_:function(){return[]},getClass:function(){return Sn}}),e(wn.prototype,{collectLines:function(t){for(var e=this.op.getGraph().getEdgeEnds().iterator();e.hasNext();){var n=e.next();this.collectLineEdge(n,t,this.lineEdgesList),this.collectBoundaryTouchEdge(n,t,this.lineEdgesList)}},labelIsolatedLine:function(t,e){var n=this.ptLocator.locate(t.getCoordinate(),this.op.getArgGeometry(e));t.getLabel().setLocation(e,n)},build:function(t){return this.findCoveredLineEdges(),this.collectLines(t),this.buildLines(t),this.resultLineList},collectLineEdge:function(t,e,n){var i=t.getLabel(),r=t.getEdge();t.isLineEdge()&&(t.isVisited()||!ii.isResultOfOp(i,e)||r.isCovered()||(n.add(r),t.setVisitedEdge(!0)))},findCoveredLineEdges:function(){for(var t=this.op.getGraph().getNodes().iterator();t.hasNext();){var e=t.next();e.getEdges().findCoveredLineEdges()}for(var n=this.op.getGraph().getEdgeEnds().iterator();n.hasNext();){var i=n.next(),r=i.getEdge();if(i.isLineEdge()&&!r.isCoveredSet()){var s=this.op.isCoveredByA(i.getCoordinate());r.setCovered(s)}}},labelIsolatedLines:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),i=n.getLabel();n.isIsolated()&&(i.isNull(0)?this.labelIsolatedLine(n,0):this.labelIsolatedLine(n,1))}},buildLines:function(t){for(var e=this.lineEdgesList.iterator();e.hasNext();){var n=e.next(),i=(n.getLabel(),this.geometryFactory.createLineString(n.getCoordinates()));this.resultLineList.add(i),n.setInResult(!0)}},collectBoundaryTouchEdge:function(t,e,n){var i=t.getLabel();return t.isLineEdge()?null:t.isVisited()?null:t.isInteriorAreaEdge()?null:t.getEdge().isInResult()?null:(f.isTrue(!(t.isInResult()||t.getSym().isInResult())||!t.getEdge().isInResult()),void(ii.isResultOfOp(i,e)&&e===ii.INTERSECTION&&(n.add(t.getEdge()),t.setVisitedEdge(!0))))},interfaces_:function(){return[]},getClass:function(){return wn}}),e(Ln.prototype,{filterCoveredNodeToPoint:function(t){var e=t.getCoordinate();if(!this.op.isCoveredByLA(e)){var n=this.geometryFactory.createPoint(e);this.resultPointList.add(n)}},extractNonCoveredResultNodes:function(t){for(var e=this.op.getGraph().getNodes().iterator();e.hasNext();){var n=e.next();if(!(n.isInResult()||n.isIncidentEdgeInResult()||0!==n.getEdges().getDegree()&&t!==ii.INTERSECTION)){var i=n.getLabel();ii.isResultOfOp(i,t)&&this.filterCoveredNodeToPoint(n)}}},build:function(t){return this.extractNonCoveredResultNodes(t),this.resultPointList},interfaces_:function(){return[]},getClass:function(){return Ln}}),e(Rn.prototype,{locate:function(t){},interfaces_:function(){return[]},getClass:function(){return Rn}}),e(Tn.prototype,{locate:function(t){return Tn.locate(t,this.geom)},interfaces_:function(){return[Rn]},getClass:function(){return Tn}}),Tn.isPointInRing=function(t,e){return!!e.getEnvelopeInternal().intersects(t)&&he.isPointInRing(t,e.getCoordinates())},Tn.containsPointInPolygon=function(t,e){if(e.isEmpty())return!1;var n=e.getExteriorRing();if(!Tn.isPointInRing(t,n))return!1;for(var i=0;i=0;n--){var i=this.edgeList.get(n),r=i.getSym();null===e&&(e=r),null!==t&&r.setNext(t),t=i}e.setNext(t)},computeDepths:function(){if(1===arguments.length){var t=arguments[0],e=this.findIndex(t),n=(t.getLabel(),t.getDepth(cn.LEFT)),i=t.getDepth(cn.RIGHT),r=this.computeDepths(e+1,this.edgeList.size(),n),s=this.computeDepths(0,e,r);if(s!==i)throw new sn(\"depth mismatch at \"+t.getCoordinate())}else if(3===arguments.length){for(var o=arguments[0],a=arguments[1],u=arguments[2],l=u,h=o;h=0;r--){var s=this.resultAreaEdgeList.get(r),o=s.getSym();switch(null===e&&s.getEdgeRing()===t&&(e=s),i){case this.SCANNING_FOR_INCOMING:if(o.getEdgeRing()!==t)continue;n=o,i=this.LINKING_TO_OUTGOING;break;case this.LINKING_TO_OUTGOING:if(s.getEdgeRing()!==t)continue;n.setNextMin(s),i=this.SCANNING_FOR_INCOMING}}i===this.LINKING_TO_OUTGOING&&(f.isTrue(null!==e,\"found null for first outgoing dirEdge\"),f.isTrue(e.getEdgeRing()===t,\"unable to link last incoming dirEdge\"),n.setNextMin(e))},getOutgoingDegree:function(){if(0===arguments.length){for(var t=0,e=this.iterator();e.hasNext();){var n=e.next();n.isInResult()&&t++}return t}if(1===arguments.length){for(var i=arguments[0],t=0,e=this.iterator();e.hasNext();){var n=e.next();n.getEdgeRing()===i&&t++}return t}},getLabel:function(){return this.label},findCoveredLineEdges:function(){for(var t=L.NONE,e=this.iterator();e.hasNext();){var n=e.next(),i=n.getSym();if(!n.isLineEdge()){if(n.isInResult()){t=L.INTERIOR;break}if(i.isInResult()){t=L.EXTERIOR;break}}}if(t===L.NONE)return null;for(var r=t,e=this.iterator();e.hasNext();){var n=e.next(),i=n.getSym();n.isLineEdge()?n.getEdge().setCovered(r===L.INTERIOR):(n.isInResult()&&(r=L.EXTERIOR),i.isInResult()&&(r=L.INTERIOR))}},computeLabelling:function(t){Pn.prototype.computeLabelling.call(this,t),this.label=new gn(L.NONE);for(var e=this.iterator();e.hasNext();)for(var n=e.next(),i=n.getEdge(),r=i.getLabel(),s=0;s<2;s++){var o=r.getLocation(s);o!==L.INTERIOR&&o!==L.BOUNDARY||this.label.setLocation(s,L.INTERIOR)}},interfaces_:function(){return[]},getClass:function(){return bn}}),h(On,Nn),e(On.prototype,{createNode:function(t){return new yn(t,new bn)},interfaces_:function(){return[]},getClass:function(){return On}}),e(_n.prototype,{computeIntersections:function(t,e){this.mce.computeIntersectsForChain(this.chainIndex,t.mce,t.chainIndex,e)},interfaces_:function(){return[]},getClass:function(){return _n}}),e(Mn.prototype,{isDelete:function(){return this.eventType===Mn.DELETE},setDeleteEventIndex:function(t){this.deleteEventIndex=t},getObject:function(){return this.obj},compareTo:function(t){var e=t;return this.xValuee.xValue?1:this.eventTypee.eventType?1:0},getInsertEvent:function(){return this.insertEvent},isInsert:function(){return this.eventType===Mn.INSERT},isSameLabel:function(t){return null!==this.label&&this.label===t.label},getDeleteEventIndex:function(){return this.deleteEventIndex},interfaces_:function(){return[s]},getClass:function(){return Mn}}),Mn.INSERT=1,Mn.DELETE=2,e(Dn.prototype,{interfaces_:function(){return[]},getClass:function(){return Dn}}),e(An.prototype,{isTrivialIntersection:function(t,e,n,i){if(t===n&&1===this.li.getIntersectionNum()){if(An.isAdjacentSegments(e,i))return!0;if(t.isClosed()){var r=t.getNumPoints()-1;if(0===e&&i===r||0===i&&e===r)return!0}}return!1},getProperIntersectionPoint:function(){return this.properIntersectionPoint},setIsDoneIfProperInt:function(t){this.isDoneWhenProperInt=t},hasProperInteriorIntersection:function(){return this.hasProperInterior},isBoundaryPointInternal:function(t,e){for(var n=e.iterator();n.hasNext();){var i=n.next(),r=i.getCoordinate();if(t.isIntersection(r))return!0}return!1},hasProperIntersection:function(){return this.hasProper},hasIntersection:function(){return this._hasIntersection},isDone:function(){return this._isDone},isBoundaryPoint:function(t,e){return null!==e&&(!!this.isBoundaryPointInternal(t,e[0])||!!this.isBoundaryPointInternal(t,e[1]))},setBoundaryNodes:function(t,e){this.bdyNodes=new Array(2).fill(null),this.bdyNodes[0]=t,this.bdyNodes[1]=e},addIntersections:function(t,e,n,i){if(t===n&&e===i)return null;this.numTests++;var r=t.getCoordinates()[e],s=t.getCoordinates()[e+1],o=n.getCoordinates()[i],a=n.getCoordinates()[i+1];this.li.computeIntersection(r,s,o,a),this.li.hasIntersection()&&(this.recordIsolated&&(t.setIsolated(!1),n.setIsolated(!1)),this.numIntersections++,this.isTrivialIntersection(t,e,n,i)||(this._hasIntersection=!0,!this.includeProper&&this.li.isProper()||(t.addIntersections(this.li,e,0),n.addIntersections(this.li,i,1)),this.li.isProper()&&(this.properIntersectionPoint=this.li.getIntersection(0).copy(),this.hasProper=!0,this.isDoneWhenProperInt&&(this._isDone=!0),this.isBoundaryPoint(this.li,this.bdyNodes)||(this.hasProperInterior=!0))))},interfaces_:function(){return[]},getClass:function(){return An}}),An.isAdjacentSegments=function(t,e){return 1===Math.abs(t-e)},h(Fn,Dn),e(Fn.prototype,{prepareEvents:function(){ho.sort(this.events);for(var t=0;te||this.maxs?1:0},interfaces_:function(){return[a]},getClass:function(){return qn}}),Gn.NodeComparator=qn,h(Bn,Gn),e(Bn.prototype,{query:function(t,e,n){return this.intersects(t,e)?void n.visitItem(this.item):null},interfaces_:function(){return[]},getClass:function(){return Bn}}),h(zn,Gn),e(zn.prototype,{buildExtent:function(t,e){this.min=Math.min(t.min,e.min),this.max=Math.max(t.max,e.max)},query:function(t,e,n){return this.intersects(t,e)?(null!==this.node1&&this.node1.query(t,e,n),void(null!==this.node2&&this.node2.query(t,e,n))):null},interfaces_:function(){return[]},getClass:function(){return zn}}),e(Vn.prototype,{buildTree:function(){ho.sort(this.leaves,new IntervalRTreeNode.NodeComparator);for(var t=this.leaves,e=null,n=new I;;){if(this.buildLevel(t,n),1===n.size())return n.get(0);e=t,t=n,n=e}},insert:function(t,e,n){if(null!==this.root)throw new IllegalStateException(\"Index cannot be added to once it has been queried\");this.leaves.add(new Bn(t,e,n))},query:function(t,e,n){this.init(),this.root.query(t,e,n)},buildRoot:function(){return null!==this.root?null:void(this.root=this.buildTree())},printNode:function(t){A.out.println(se.toLineString(new g(t.min,this.level),new g(t.max,this.level)))},init:function(){return null!==this.root?null:void this.buildRoot()},buildLevel:function(t,e){this.level++,e.clear();for(var n=0;nt?1:this.diste?1:0},interfaces_:function(){return[s]},getClass:function(){return Wn}}),e(jn.prototype,{print:function(t){t.println(\"Intersections:\");for(var e=this.iterator();e.hasNext();){var n=e.next();n.print(t)}},iterator:function(){return this.nodeMap.values().iterator()},addSplitEdges:function(t){this.addEndpoints();for(var e=this.iterator(),n=e.next();e.hasNext();){var i=e.next(),r=this.createSplitEdge(n,i);t.add(r),n=i}},addEndpoints:function(){var t=this.edge.pts.length-1;this.add(this.edge.pts[0],0,0),this.add(this.edge.pts[t],t,0)},createSplitEdge:function(t,e){var n=e.segmentIndex-t.segmentIndex+2,i=this.edge.pts[e.segmentIndex],r=e.dist>0||!e.coord.equals2D(i);r||n--;var s=new Array(n).fill(null),o=0;s[o++]=new g(t.coord);for(var a=t.segmentIndex+1;a<=e.segmentIndex;a++)s[o++]=this.edge.pts[a];return r&&(s[o]=e.coord),new Jn(s,new gn(this.edge.label))},add:function(t,e,n){var i=new Wn(t,e,n),r=this.nodeMap.get(i);return null!==r?r:(this.nodeMap.put(i,i),i)},isIntersection:function(t){for(var e=this.iterator();e.hasNext();){var n=e.next();if(n.coord.equals(t))return!0}return!1},interfaces_:function(){return[]},getClass:function(){return jn}}),e(Kn.prototype,{getChainStartIndices:function(t){var e=0,n=new I;n.add(new b(e));do{var i=this.findChainEnd(t,e);n.add(new b(i)),e=i}while(en?e:n},getMinX:function(t){var e=this.pts[this.startIndex[t]].x,n=this.pts[this.startIndex[t+1]].x;return ee&&(i=1),this.depth[t][n]=i}}},getDelta:function(t){return this.depth[t][cn.RIGHT]-this.depth[t][cn.LEFT]},getLocation:function(t,e){return this.depth[t][e]<=0?L.EXTERIOR:L.INTERIOR},toString:function(){return\"A: \"+this.depth[0][1]+\",\"+this.depth[0][2]+\" B: \"+this.depth[1][1]+\",\"+this.depth[1][2]},add:function(){if(1===arguments.length)for(var t=arguments[0],e=0;e<2;e++)for(var n=1;n<3;n++){var i=t.getLocation(e,n);i!==L.EXTERIOR&&i!==L.INTERIOR||(this.isNull(e,n)?this.depth[e][n]=Qn.depthAtLocation(i):this.depth[e][n]+=Qn.depthAtLocation(i))}else if(3===arguments.length){var r=arguments[0],s=arguments[1],o=arguments[2];o===L.INTERIOR&&this.depth[r][s]++}},interfaces_:function(){return[]},getClass:function(){return Qn}}),Qn.depthAtLocation=function(t){return t===L.EXTERIOR?0:t===L.INTERIOR?1:Qn.NULL_VALUE},Qn.NULL_VALUE=-1,h(Jn,mn),e(Jn.prototype,{getDepth:function(){return this.depth},getCollapsedEdge:function(){var t=new Array(2).fill(null);t[0]=this.pts[0],t[1]=this.pts[1];var e=new Jn(t,gn.toLineLabel(this.label));return e},isIsolated:function(){return this._isIsolated},getCoordinates:function(){return this.pts},setIsolated:function(t){this._isIsolated=t},setName:function(t){this.name=t},equals:function(t){if(!(t instanceof Jn))return!1;var e=t;if(this.pts.length!==e.pts.length)return!1;for(var n=!0,i=!0,r=this.pts.length,s=0;s0?this.pts[0]:null;if(1===arguments.length){var t=arguments[0];return this.pts[t]}},print:function(t){t.print(\"edge \"+this.name+\": \"),t.print(\"LINESTRING (\");for(var e=0;e0&&t.print(\",\"),t.print(this.pts[e].x+\" \"+this.pts[e].y);t.print(\") \"+this.label+\" \"+this.depthDelta)},computeIM:function(t){Jn.updateIM(this.label,t)},isCollapsed:function(){return!!this.label.isArea()&&(3===this.pts.length&&!!this.pts[0].equals(this.pts[2]))},isClosed:function(){return this.pts[0].equals(this.pts[this.pts.length-1])},getMaximumSegmentIndex:function(){return this.pts.length-1},getDepthDelta:function(){return this.depthDelta},getNumPoints:function(){return this.pts.length},printReverse:function(t){t.print(\"edge \"+this.name+\": \");for(var e=this.pts.length-1;e>=0;e--)t.print(this.pts[e]+\" \");t.println(\"\")},getMonotoneChainEdge:function(){return null===this.mce&&(this.mce=new Zn(this)),this.mce},getEnvelope:function(){if(null===this.env){this.env=new C;for(var t=0;t0&&t.append(\",\"),t.append(this.pts[e].x+\" \"+this.pts[e].y);return t.append(\") \"+this.label+\" \"+this.depthDelta),t.toString()},isPointwiseEqual:function(t){if(this.pts.length!==t.pts.length)return!1;for(var e=0;e=2,\"found LineString with single point\"),this.insertBoundaryPoint(this.argIndex,e[0]),this.insertBoundaryPoint(this.argIndex,e[e.length-1])},getInvalidPoint:function(){return this.invalidPoint},getBoundaryPoints:function(){for(var t=this.getBoundaryNodes(),e=new Array(t.size()).fill(null),n=0,i=t.iterator();i.hasNext();){var r=i.next();e[n++]=r.getCoordinate().copy()}return e},getBoundaryNodes:function(){return null===this.boundaryNodes&&(this.boundaryNodes=this.nodes.getBoundaryNodes(this.argIndex)),this.boundaryNodes},addSelfIntersectionNode:function(t,e,n){return this.isBoundaryNode(t,e)?null:void(n===L.BOUNDARY&&this.useBoundaryDeterminationRule?this.insertBoundaryPoint(t,e):this.insertPoint(t,e,n))},addPolygonRing:function(t,e,n){if(t.isEmpty())return null;var i=H.removeRepeatedPoints(t.getCoordinates());if(i.length<4)return this._hasTooFewPoints=!0,this.invalidPoint=i[0],null;var r=e,s=n;he.isCCW(i)&&(r=n,s=e);var o=new Jn(i,new gn(this.argIndex,L.BOUNDARY,r,s));this.lineEdgeMap.put(t,o),this.insertEdge(o),this.insertPoint(this.argIndex,i[0],L.BOUNDARY)},insertPoint:function(t,e,n){var i=this.nodes.addNode(e),r=i.getLabel();null===r?i.label=new gn(t,n):r.setLocation(t,n)},createEdgeSetIntersector:function(){return new Fn},addSelfIntersectionNodes:function(t){for(var e=this.edges.iterator();e.hasNext();)for(var n=e.next(),i=n.getLabel().getLocation(t),r=n.eiList.iterator();r.hasNext();){var s=r.next();this.addSelfIntersectionNode(t,s.coord,i)}},add:function(){if(1!==arguments.length)return Cn.prototype.add.apply(this,arguments);var t=arguments[0];if(t.isEmpty())return null;if(t instanceof Ot&&(this.useBoundaryDeterminationRule=!1),t instanceof Tt)this.addPolygon(t);else if(t instanceof St)this.addLineString(t);else if(t instanceof Lt)this.addPoint(t);else if(t instanceof Pt)this.addCollection(t);else if(t instanceof gt)this.addCollection(t);else if(t instanceof Ot)this.addCollection(t);else{if(!(t instanceof ft))throw new UnsupportedOperationException(t.getClass().getName());this.addCollection(t)}},addCollection:function(t){for(var e=0;e50?(null===this.areaPtLocator&&(this.areaPtLocator=new Un(this.parentGeom)),this.areaPtLocator.locate(t)):this.ptLocator.locate(t,this.parentGeom)},findEdge:function(){if(1===arguments.length){var t=arguments[0];return this.lineEdgeMap.get(t)}return Cn.prototype.findEdge.apply(this,arguments)},interfaces_:function(){return[]},getClass:function(){return $n}}),$n.determineBoundary=function(t,e){return t.isInBoundary(e)?L.BOUNDARY:L.INTERIOR},e(ti.prototype,{getArgGeometry:function(t){return this.arg[t].getGeometry()},setComputationPrecision:function(t){this.resultPrecisionModel=t,this.li.setPrecisionModel(this.resultPrecisionModel)},interfaces_:function(){return[]},getClass:function(){return ti}}),e(ei.prototype,{compareTo:function(t){var e=t,n=ei.compareOriented(this.pts,this._orientation,e.pts,e._orientation);return n},interfaces_:function(){return[s]},getClass:function(){return ei}}),ei.orientation=function(t){return 1===H.increasingDirection(t)},ei.compareOriented=function(t,e,n,i){for(var r=e?1:-1,s=i?1:-1,o=e?t.length:-1,a=i?n.length:-1,u=e?0:t.length-1,l=i?0:n.length-1;;){var h=t[u].compareTo(n[l]);if(0!==h)return h;u+=r,l+=s;var c=u===o,f=l===a;if(c&&!f)return-1;if(!c&&f)return 1;if(c&&f)return 0}},e(ni.prototype,{print:function(t){t.print(\"MULTILINESTRING ( \");for(var e=0;e0&&t.print(\",\"),t.print(\"(\");for(var i=n.getCoordinates(),r=0;r0&&t.print(\",\"),t.print(i[r].x+\" \"+i[r].y);t.println(\")\")}t.print(\") \")},addAll:function(t){for(var e=t.iterator();e.hasNext();)this.add(e.next())},findEdgeIndex:function(t){for(var e=0;ethis.maxWidth)&&(this.interiorPoint=e,this.maxWidth=n)},getInteriorPoint:function(){return this.interiorPoint},widestGeometry:function t(){if(arguments[0]instanceof ft){var e=arguments[0];if(e.isEmpty())return e;for(var t=e.getGeometryN(0),n=1;nt.getEnvelopeInternal().getWidth()&&(t=e.getGeometryN(n));return t}if(arguments[0]instanceof B){var i=arguments[0];return i instanceof ft?this.widestGeometry(i):i}},horizontalBisector:function(t){var e=t.getEnvelopeInternal(),n=ai.getBisectorY(t);return this.factory.createLineString([new g(e.getMinX(),n),new g(e.getMaxX(),n)])},add:function(t){if(t instanceof Tt)this.addPolygon(t);else if(t instanceof ft)for(var e=t,n=0;nthis.loY&&(this.loY=t):t>this.centreY&&tt&&(t=n)}return t+1},nodeSize:function(){for(var t=0,e=0;e<2;e++)null!==this.subnode[e]&&(t+=this.subnode[e].nodeSize());return t+1},add:function(t){this.items.add(t)},interfaces_:function(){return[]},getClass:function(){return ci}}),ci.getSubnodeIndex=function(t,e){var n=-1;return t.min>=e&&(n=1),t.max<=e&&(n=0),n},e(fi.prototype,{expandToInclude:function(t){t.max>this.max&&(this.max=t.max),t.minn||this.max=this.min&&e<=this.max}}else if(2===arguments.length){var n=arguments[0],i=arguments[1];return n>=this.min&&i<=this.max}},init:function(t,e){this.min=t,this.max=e,t>e&&(this.min=e,this.max=t)},getMax:function(){return this.max},interfaces_:function(){return[]},getClass:function(){return fi}}),gi.exponent=function(t){return di(64,t)-1023},gi.powerOf2=function(t){return Math.pow(2,t)},e(pi.prototype,{getInterval:function(){return this.interval},getLevel:function(){return this.level},computeKey:function(t){for(this.level=pi.computeLevel(t),this.interval=new fi,this.computeInterval(this.level,t);!this.interval.contains(t);)this.level+=1,this.computeInterval(this.level,t)},computeInterval:function(t,e){var n=gi.powerOf2(t);this.pt=Math.floor(e.getMin()/n)*n,this.interval.init(this.pt,this.pt+n)},getPoint:function(){return this.pt},interfaces_:function(){return[]},getClass:function(){return pi}}),pi.computeLevel=function(t){var e=t.getWidth(),n=gi.exponent(e)+1;return n},h(vi,ci),e(vi.prototype,{getInterval:function(){return this.interval},find:function(t){var e=ci.getSubnodeIndex(t,this.centre);if(e===-1)return this;if(null!==this.subnode[e]){var n=this.subnode[e];return n.find(t)}return this},insert:function(t){f.isTrue(null===this.interval||this.interval.contains(t.interval));var e=ci.getSubnodeIndex(t.interval,this.centre);if(t.level===this.level-1)this.subnode[e]=t;else{var n=this.createSubnode(e);n.insert(t),this.subnode[e]=n}},isSearchMatch:function(t){return t.overlaps(this.interval)},getSubnode:function(t){return null===this.subnode[t]&&(this.subnode[t]=this.createSubnode(t)),this.subnode[t]},getNode:function(t){var e=ci.getSubnodeIndex(t,this.centre);if(e!==-1){var n=this.getSubnode(e);return n.getNode(t)}return this},createSubnode:function(t){var e=0,n=0;switch(t){case 0:e=this.interval.getMin(),n=this.centre;break;case 1:e=this.centre,n=this.interval.getMax()}var i=new fi(e,n),r=new vi(i,this.level-1);return r},interfaces_:function(){return[]},getClass:function(){return vi}}),vi.createNode=function(t){var e=new pi(t),n=new vi(e.getInterval(),e.getLevel());return n},vi.createExpanded=function(t,e){var n=new fi(e);null!==t&&n.expandToInclude(t.interval);var i=vi.createNode(n);return null!==t&&i.insert(t),i},e(mi.prototype,{interfaces_:function(){return[]},getClass:function(){return mi}});mi.isZeroWidth=function(t,e){var n=e-t;if(0===n)return!0;var i=Math.max(Math.abs(t),Math.abs(e)),r=n/i,s=gi.exponent(r);return s<=mi.MIN_BINARY_EXPONENT};mi.MIN_BINARY_EXPONENT=-50,h(yi,ci),e(yi.prototype,{insert:function(t,e){var n=ci.getSubnodeIndex(t,yi.origin);if(n===-1)return this.add(e),null;var i=this.subnode[n];if(null===i||!i.getInterval().contains(t)){var r=vi.createExpanded(i,t);this.subnode[n]=r}this.insertContained(this.subnode[n],t,e)},isSearchMatch:function(t){return!0},insertContained:function(t,e,n){f.isTrue(t.getInterval().contains(e));var i=mi.isZeroWidth(e.getMin(),e.getMax()),r=null;r=i?t.find(e):t.getNode(e),r.add(n)},interfaces_:function(){return[]},getClass:function(){return yi}}),yi.origin=0,e(xi.prototype,{size:function(){return null!==this.root?this.root.size():0},insert:function(t,e){this.collectStats(t);var n=xi.ensureExtent(t,this.minExtent);this.root.insert(n,e)},query:function(){if(1===arguments.length){if(\"number\"==typeof arguments[0]){var t=arguments[0];return this.query(new fi(t,t))}if(arguments[0]instanceof fi){var e=arguments[0],n=new I;return this.query(e,n),n}}else if(2===arguments.length){var i=arguments[0],r=arguments[1];this.root.addAllItemsFromOverlapping(i,r)}},iterator:function(){var t=new I;return this.root.addAllItems(t),t.iterator()},remove:function(t,e){var n=xi.ensureExtent(t,this.minExtent);return this.root.remove(n,e)},collectStats:function(t){var e=t.getWidth();e0&&(this.minExtent=e)},depth:function(){return null!==this.root?this.root.depth():0},nodeSize:function(){return null!==this.root?this.root.nodeSize():0},interfaces_:function(){return[]},getClass:function(){return xi}}),xi.ensureExtent=function(t,e){var n=t.getMin(),i=t.getMax();return n!==i?t:(n===i&&(n-=e/2,i=n+e/2),new fi(n,i))},e(Ei.prototype,{isInside:function(t){},interfaces_:function(){return[]},getClass:function(){return Ei}}),e(Ii.prototype,{testLineSegment:function(t,e){var n=null,i=null,r=null,s=null,o=null,a=e.p0,u=e.p1;i=a.x-t.x,r=a.y-t.y,s=u.x-t.x,o=u.y-t.y,(r>0&&o<=0||o>0&&r<=0)&&(n=ue.signOfDet2x2(i,r,s,o)/(o-r),0Math.PI;)t-=Ci.PI_TIMES_2;for(;t<=-Math.PI;)t+=Ci.PI_TIMES_2;return t},Ci.angle=function(){if(1===arguments.length){var t=arguments[0];return Math.atan2(t.y,t.x)}if(2===arguments.length){var e=arguments[0],n=arguments[1],i=n.x-e.x,r=n.y-e.y;return Math.atan2(r,i)}},Ci.isAcute=function(t,e,n){var i=t.x-e.x,r=t.y-e.y,s=n.x-e.x,o=n.y-e.y,a=i*s+r*o;return a>0},Ci.isObtuse=function(t,e,n){var i=t.x-e.x,r=t.y-e.y,s=n.x-e.x,o=n.y-e.y,a=i*s+r*o;return a<0},Ci.interiorAngle=function(t,e,n){var i=Ci.angle(e,t),r=Ci.angle(e,n);return Math.abs(r-i)},Ci.normalizePositive=function(t){if(t<0){for(;t<0;)t+=Ci.PI_TIMES_2;t>=Ci.PI_TIMES_2&&(t=0)}else{for(;t>=Ci.PI_TIMES_2;)t-=Ci.PI_TIMES_2;t<0&&(t=0)}return t},Ci.angleBetween=function(t,e,n){var i=Ci.angle(e,t),r=Ci.angle(e,n);return Ci.diff(i,r)},Ci.diff=function(t,e){var n=null;return n=tMath.PI&&(n=2*Math.PI-n),n},Ci.toRadians=function(t){return t*Math.PI/180},Ci.getTurn=function(t,e){var n=Math.sin(e-t);return n>0?Ci.COUNTERCLOCKWISE:n<0?Ci.CLOCKWISE:Ci.NONE},Ci.angleBetweenOriented=function(t,e,n){var i=Ci.angle(e,t),r=Ci.angle(e,n),s=r-i;return s<=-Math.PI?s+Ci.PI_TIMES_2:s>Math.PI?s-Ci.PI_TIMES_2:s},Ci.PI_TIMES_2=2*Math.PI,Ci.PI_OVER_2=Math.PI/2,Ci.PI_OVER_4=Math.PI/4,Ci.COUNTERCLOCKWISE=he.COUNTERCLOCKWISE,Ci.CLOCKWISE=he.CLOCKWISE,Ci.NONE=he.COLLINEAR,e(Si.prototype,{area:function(){return Si.area(this.p0,this.p1,this.p2)},signedArea:function(){return Si.signedArea(this.p0,this.p1,this.p2)},interpolateZ:function(t){if(null===t)throw new i(\"Supplied point is null.\");return Si.interpolateZ(t,this.p0,this.p1,this.p2)},longestSideLength:function(){return Si.longestSideLength(this.p0,this.p1,this.p2)},isAcute:function(){return Si.isAcute(this.p0,this.p1,this.p2)},circumcentre:function(){return Si.circumcentre(this.p0,this.p1,this.p2)},area3D:function(){return Si.area3D(this.p0,this.p1,this.p2)},centroid:function(){return Si.centroid(this.p0,this.p1,this.p2)},inCentre:function(){return Si.inCentre(this.p0,this.p1,this.p2)},interfaces_:function(){return[]},getClass:function(){return Si}}),Si.area=function(t,e,n){return Math.abs(((n.x-t.x)*(e.y-t.y)-(e.x-t.x)*(n.y-t.y))/2)},Si.signedArea=function(t,e,n){return((n.x-t.x)*(e.y-t.y)-(e.x-t.x)*(n.y-t.y))/2},Si.det=function(t,e,n,i){return t*i-e*n},Si.interpolateZ=function(t,e,n,i){var r=e.x,s=e.y,o=n.x-r,a=i.x-r,u=n.y-s,l=i.y-s,h=o*l-a*u,c=t.x-r,f=t.y-s,g=(l*c-a*f)/h,d=(-u*c+o*f)/h,p=e.z+g*(n.z-e.z)+d*(i.z-e.z);return p},Si.longestSideLength=function(t,e,n){var i=t.distance(e),r=e.distance(n),s=n.distance(t),o=i;return r>o&&(o=r),s>o&&(o=s),o},Si.isAcute=function(t,e,n){return!!Ci.isAcute(t,e,n)&&(!!Ci.isAcute(e,n,t)&&!!Ci.isAcute(n,t,e))},Si.circumcentre=function(t,e,n){var i=n.x,r=n.y,s=t.x-i,o=t.y-r,a=e.x-i,u=e.y-r,l=2*Si.det(s,o,a,u),h=Si.det(o,s*s+o*o,u,a*a+u*u),c=Si.det(s,s*s+o*o,a,a*a+u*u),f=i-h/l,d=r+c/l;return new g(f,d)},Si.perpendicularBisector=function(t,e){var n=e.x-t.x,i=e.y-t.y,r=new F(t.x+n/2,t.y+i/2,1),s=new F(t.x-i+n/2,t.y+n+i/2,1);return new F(r,s)},Si.angleBisector=function(t,e,n){var i=e.distance(t),r=e.distance(n),s=i/(i+r),o=n.x-t.x,a=n.y-t.y,u=new g(t.x+s*o,t.y+s*a);return u},Si.area3D=function(t,e,n){var i=e.x-t.x,r=e.y-t.y,s=e.z-t.z,o=n.x-t.x,a=n.y-t.y,u=n.z-t.z,l=r*u-s*a,h=s*o-i*u,c=i*a-r*o,f=l*l+h*h+c*c,g=Math.sqrt(f)/2;return g},Si.centroid=function(t,e,n){var i=(t.x+e.x+n.x)/3,r=(t.y+e.y+n.y)/3;return new g(i,r)},Si.inCentre=function(t,e,n){var i=e.distance(n),r=t.distance(n),s=t.distance(e),o=i+r+s,a=(i*t.x+r*e.x+s*n.x)/o,u=(i*t.y+r*e.y+s*n.y)/o;return new g(a,u)},e(wi.prototype,{getRadius:function(){return this.compute(),this.radius},getDiameter:function(){switch(this.compute(),this.extremalPts.length){case 0:return this.input.getFactory().createLineString();case 1:return this.input.getFactory().createPoint(this.centre)}var t=this.extremalPts[0],e=this.extremalPts[1];return this.input.getFactory().createLineString([t,e])},getExtremalPoints:function(){return this.compute(),this.extremalPts},computeCirclePoints:function(){if(this.input.isEmpty())return this.extremalPts=new Array(0).fill(null),null;if(1===this.input.getNumPoints()){var t=this.input.getCoordinates();return this.extremalPts=[new g(t[0])],null}var e=this.input.convexHull(),n=e.getCoordinates(),t=n;if(n[0].equals2D(n[n.length-1])&&(t=new Array(n.length-1).fill(null),H.copyDeep(n,0,t,0,n.length-1)),t.length<=2)return this.extremalPts=H.copyDeep(t),null;for(var i=wi.lowestPoint(t),r=wi.pointWitMinAngleWithX(t,i),s=0;s=i;)i=r,s=o,o=Li.nextIndex(t,s),r=e.distancePerpendicular(t[o]);return ii&&(i=u),uo&&(o=l),l=t.length&&(e=0),e},Li.computeC=function(t,e,n){return t*n.y-e*n.x},Li.getMinimumDiameter=function(t){return new Li(t).getDiameter()},Li.getMinimumRectangle=function(t){return new Li(t).getMinimumRectangle()},Li.computeSegmentForLine=function(t,e,n){var i=null,r=null;return Math.abs(e)>Math.abs(t)?(i=new g(0,n/e),r=new g(1,n/e-t/e)):(i=new g(n/t,0),r=new g(n/t-e/t,1)),new ce(i,r)};var co=Object.freeze({Centroid:ge,CGAlgorithms:he,ConvexHull:me,InteriorPointArea:oi,InteriorPointLine:ui,InteriorPointPoint:li,RobustLineIntersector:ae,MCPointInRing:Ii,MinimumBoundingCircle:wi,MinimumDiameter:Li});e(Ri.prototype,{getResultGeometry:function(){return new Ti(this.distanceTolerance).transform(this.inputGeom)},setDistanceTolerance:function(t){if(t<=0)throw new i(\"Tolerance must be positive\");this.distanceTolerance=t},interfaces_:function(){return[]},getClass:function(){return Ri}}),Ri.densifyPoints=function(t,e,n){for(var i=new ce,r=new N,s=0;s1)for(var u=o/a,l=1;lo?1:st&&(t=n)}return t+1},isEmpty:function t(){var t=!0;this.items.isEmpty()||(t=!1);for(var e=0;e<4;e++)null!==this.subnode[e]&&(this.subnode[e].isEmpty()||(t=!1));return t},add:function(t){this.items.add(t)},interfaces_:function(){return[u]},getClass:function(){return Ai}}),Ai.getSubnodeIndex=function(t,e,n){var i=-1;return t.getMinX()>=e&&(t.getMinY()>=n&&(i=3),t.getMaxY()<=n&&(i=1)),t.getMaxX()<=e&&(t.getMinY()>=n&&(i=2),t.getMaxY()<=n&&(i=0)),i},e(Fi.prototype,{getLevel:function(){return this.level},computeKey:function(){if(1===arguments.length){var t=arguments[0];for(this.level=Fi.computeQuadLevel(t),this.env=new C,this.computeKey(this.level,t);!this.env.contains(t);)this.level+=1,this.computeKey(this.level,t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1],i=gi.powerOf2(e);this.pt.x=Math.floor(n.getMinX()/i)*i,this.pt.y=Math.floor(n.getMinY()/i)*i,this.env.init(this.pt.x,this.pt.x+i,this.pt.y,this.pt.y+i)}},getEnvelope:function(){return this.env},getCentre:function(){return new g((this.env.getMinX()+this.env.getMaxX())/2,(this.env.getMinY()+this.env.getMaxY())/2)},getPoint:function(){return this.pt},interfaces_:function(){return[]},getClass:function(){return Fi}}),Fi.computeQuadLevel=function(t){var e=t.getWidth(),n=t.getHeight(),i=e>n?e:n,r=gi.exponent(i)+1;return r},h(Gi,Ai),e(Gi.prototype,{find:function(t){var e=Ai.getSubnodeIndex(t,this.centrex,this.centrey);if(e===-1)return this;if(null!==this.subnode[e]){var n=this.subnode[e];return n.find(t)}return this},isSearchMatch:function(t){return this.env.intersects(t)},getSubnode:function(t){return null===this.subnode[t]&&(this.subnode[t]=this.createSubnode(t)),this.subnode[t]},getEnvelope:function(){return this.env},getNode:function(t){var e=Ai.getSubnodeIndex(t,this.centrex,this.centrey);if(e!==-1){var n=this.getSubnode(e);return n.getNode(t)}return this},createSubnode:function(t){var e=0,n=0,i=0,r=0;switch(t){case 0:e=this.env.getMinX(),n=this.centrex,i=this.env.getMinY(),r=this.centrey;break;case 1:e=this.centrex,n=this.env.getMaxX(),i=this.env.getMinY(),r=this.centrey;break;case 2:e=this.env.getMinX(),n=this.centrex,i=this.centrey,r=this.env.getMaxY();break;case 3:e=this.centrex,n=this.env.getMaxX(),i=this.centrey,r=this.env.getMaxY()}var s=new C(e,n,i,r),o=new Gi(s,this.level-1);return o},insertNode:function(t){f.isTrue(null===this.env||this.env.contains(t.env));var e=Ai.getSubnodeIndex(t.env,this.centrex,this.centrey);if(t.level===this.level-1)this.subnode[e]=t;else{var n=this.createSubnode(e);n.insertNode(t),this.subnode[e]=n}},interfaces_:function(){return[]},getClass:function(){return Gi}}),Gi.createNode=function(t){var e=new Fi(t),n=new Gi(e.getEnvelope(),e.getLevel());return n},Gi.createExpanded=function(t,e){var n=new C(e);null!==t&&n.expandToInclude(t.env);var i=Gi.createNode(n);return null!==t&&i.insertNode(t),i},h(qi,Ai),e(qi.prototype,{insert:function(t,e){var n=Ai.getSubnodeIndex(t,qi.origin.x,qi.origin.y);if(n===-1)return this.add(e),null;var i=this.subnode[n];if(null===i||!i.getEnvelope().contains(t)){var r=Gi.createExpanded(i,t);this.subnode[n]=r}this.insertContained(this.subnode[n],t,e)},isSearchMatch:function(t){return!0},insertContained:function(t,e,n){f.isTrue(t.getEnvelope().contains(e));var i=mi.isZeroWidth(e.getMinX(),e.getMaxX()),r=mi.isZeroWidth(e.getMinY(),e.getMaxY()),s=null;s=i||r?t.find(e):t.getNode(e),s.add(n)},interfaces_:function(){return[]},getClass:function(){return qi}}),qi.origin=new g(0,0),e(Bi.prototype,{size:function(){return null!==this.root?this.root.size():0},insert:function(t,e){this.collectStats(t);var n=Bi.ensureExtent(t,this.minExtent);this.root.insert(n,e)},query:function(){if(1===arguments.length){var t=arguments[0],e=new Yn;return this.query(t,e),e.getItems()}if(2===arguments.length){var n=arguments[0],i=arguments[1];this.root.visit(n,i)}},queryAll:function(){var t=new I;return this.root.addAllItems(t),t},remove:function(t,e){var n=Bi.ensureExtent(t,this.minExtent);return this.root.remove(n,e)},collectStats:function(t){var e=t.getWidth();e0&&(this.minExtent=e);var n=t.getHeight();n0&&(this.minExtent=n)},depth:function(){return null!==this.root?this.root.depth():0},isEmpty:function(){return null===this.root},interfaces_:function(){return[Fe,u]},getClass:function(){return Bi}}),Bi.ensureExtent=function(t,e){var n=t.getMinX(),i=t.getMaxX(),r=t.getMinY(),s=t.getMaxY();return n!==i&&r!==s?t:(n===i&&(n-=e/2,i=n+e/2),r===s&&(r-=e/2,s=r+e/2),new C(n,i,r,s))},Bi.serialVersionUID=-0x678b60c967a25400;var vo=Object.freeze({Quadtree:Bi}),mo=Object.freeze({STRtree:ke}),yo=Object.freeze({quadtree:vo,strtree:mo}),xo=[\"Point\",\"MultiPoint\",\"LineString\",\"MultiLineString\",\"Polygon\",\"MultiPolygon\"];e(zi.prototype,{read:function(t){var e=void 0;e=\"string\"==typeof t?JSON.parse(t):t;var n=e.type;if(!Eo[n])throw new Error(\"Unknown GeoJSON type: \"+e.type);return xo.indexOf(n)!==-1?Eo[n].apply(this,[e.coordinates]):\"GeometryCollection\"===n?Eo[n].apply(this,[e.geometries]):Eo[n].apply(this,[e])},write:function(t){var e=t.getGeometryType();if(!Io[e])throw new Error(\"Geometry is not supported\");return Io[e].apply(this,[t])}});var Eo={Feature:function(t){var e={};for(var n in t)e[n]=t[n];if(t.geometry){var i=t.geometry.type;if(!Eo[i])throw new Error(\"Unknown GeoJSON type: \"+t.type);e.geometry=this.read(t.geometry)}return t.bbox&&(e.bbox=Eo.bbox.apply(this,[t.bbox])),e},FeatureCollection:function(t){var e={};if(t.features){e.features=[];for(var n=0;n0&&this.minIndexthis.minCoord.y&&n.y>this.minCoord.y&&i===he.CLOCKWISE&&(r=!0),r&&(this.minIndex=this.minIndex-1)},getRightmostSideOfSegment:function(t,e){var n=t.getEdge(),i=n.getCoordinates();if(e<0||e+1>=i.length)return-1;if(i[e].y===i[e+1].y)return-1;var r=cn.LEFT;return i[e].ythis.minCoord.x)&&(this.minDe=t,this.minIndex=n,this.minCoord=e[n])},findRightmostEdgeAtNode:function(){var t=this.minDe.getNode(),e=t.getEdges();this.minDe=e.getRightmostEdge(),this.minDe.isForward()||(this.minDe=this.minDe.getSym(),this.minIndex=this.minDe.getEdge().getCoordinates().length-1)},findEdge:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next();n.isForward()&&this.checkForRightmostCoordinate(n)}f.isTrue(0!==this.minIndex||this.minCoord.equals(this.minDe.getCoordinate()),\"inconsistency in rightmost processing\"),0===this.minIndex?this.findRightmostEdgeAtNode():this.findRightmostEdgeAtVertex(),this.orientedDe=this.minDe;var i=this.getRightmostSide(this.minDe,this.minIndex);i===cn.LEFT&&(this.orientedDe=this.minDe.getSym())},interfaces_:function(){return[]},getClass:function(){return Zi}}),Qi.prototype.addLast=function(t){this.array_.push(t)},Qi.prototype.removeFirst=function(){return this.array_.shift()},Qi.prototype.isEmpty=function(){return 0===this.array_.length},e(Ji.prototype,{clearVisitedEdges:function(){for(var t=this.dirEdgeList.iterator();t.hasNext();){var e=t.next();e.setVisited(!1)}},getRightmostCoordinate:function(){return this.rightMostCoord},computeNodeDepth:function(t){for(var e=null,n=t.getEdges().iterator();n.hasNext();){var i=n.next();if(i.isVisited()||i.getSym().isVisited()){e=i;break}}if(null===e)throw new sn(\"unable to find edge to compute depths at \"+t.getCoordinate());t.getEdges().computeDepths(e);for(var n=t.getEdges().iterator();n.hasNext();){var i=n.next();i.setVisited(!0),this.copySymDepths(i)}},computeDepth:function(t){this.clearVisitedEdges();var e=this.finder.getEdge();e.getNode(),e.getLabel();e.setEdgeDepths(cn.RIGHT,t),this.copySymDepths(e),this.computeDepths(e)},create:function(t){this.addReachable(t),this.finder.findEdge(this.dirEdgeList),this.rightMostCoord=this.finder.getCoordinate()},findResultEdges:function(){for(var t=this.dirEdgeList.iterator();t.hasNext();){var e=t.next();e.getDepth(cn.RIGHT)>=1&&e.getDepth(cn.LEFT)<=0&&!e.isInteriorAreaEdge()&&e.setInResult(!0)}},computeDepths:function(t){var e=new J,n=new Qi,i=t.getNode();for(n.addLast(i),e.add(i),t.setVisited(!0);!n.isEmpty();){var r=n.removeFirst();e.add(r),this.computeNodeDepth(r);for(var s=r.getEdges().iterator();s.hasNext();){var o=s.next(),a=o.getSym();if(!a.isVisited()){var u=a.getNode();e.contains(u)||(n.addLast(u),e.add(u))}}}},compareTo:function(t){var e=t;return this.rightMostCoord.xe.rightMostCoord.x?1:0},getEnvelope:function(){if(null===this.env){for(var t=new C,e=this.dirEdgeList.iterator();e.hasNext();)for(var n=e.next(),i=n.getEdge().getCoordinates(),r=0;r=0;n--)this.addPt(t[n])},isRedundant:function(t){if(this.ptList.size()<1)return!1;var e=this.ptList.get(this.ptList.size()-1),n=t.distance(e);return n=2&&(n=this.ptList.get(this.ptList.size()-2)),t.equals(e)?null:void this.ptList.add(t)},setMinimumVertexDistance:function(t){this.minimimVertexDistance=t},interfaces_:function(){return[]},getClass:function(){return tr}}),tr.COORDINATE_ARRAY_TYPE=new Array(0).fill(null),e(er.prototype,{addNextSegment:function(t,e){if(this.s0=this.s1,this.s1=this.s2,this.s2=t,this.seg0.setCoordinates(this.s0,this.s1),this.computeOffsetSegment(this.seg0,this.side,this.distance,this.offset0),this.seg1.setCoordinates(this.s1,this.s2),this.computeOffsetSegment(this.seg1,this.side,this.distance,this.offset1),this.s1.equals(this.s2))return null;var n=he.computeOrientation(this.s0,this.s1,this.s2),i=n===he.CLOCKWISE&&this.side===cn.LEFT||n===he.COUNTERCLOCKWISE&&this.side===cn.RIGHT;0===n?this.addCollinear(e):i?this.addOutsideTurn(n,e):this.addInsideTurn(n,e)},addLineEndCap:function(t,e){var n=new ce(t,e),i=new ce;this.computeOffsetSegment(n,cn.LEFT,this.distance,i);var r=new ce;this.computeOffsetSegment(n,cn.RIGHT,this.distance,r);var s=e.x-t.x,o=e.y-t.y,a=Math.atan2(o,s);switch(this.bufParams.getEndCapStyle()){case Ki.CAP_ROUND:this.segList.addPt(i.p1),this.addFilletArc(e,a+Math.PI/2,a-Math.PI/2,he.CLOCKWISE,this.distance),this.segList.addPt(r.p1);break;case Ki.CAP_FLAT:this.segList.addPt(i.p1),this.segList.addPt(r.p1);break;case Ki.CAP_SQUARE:var u=new g;u.x=Math.abs(this.distance)*Math.cos(a),u.y=Math.abs(this.distance)*Math.sin(a);var l=new g(i.p1.x+u.x,i.p1.y+u.y),h=new g(r.p1.x+u.x,r.p1.y+u.y);this.segList.addPt(l),this.segList.addPt(h)}},getCoordinates:function(){var t=this.segList.getCoordinates();return t},addMitreJoin:function(t,e,n,i){var r=!0,s=null;try{s=F.intersection(e.p0,e.p1,n.p0,n.p1);var o=i<=0?1:s.distance(t)/Math.abs(i);o>this.bufParams.getMitreLimit()&&(r=!1)}catch(t){if(!(t instanceof w))throw t;s=new g(0,0),r=!1}finally{}r?this.segList.addPt(s):this.addLimitedMitreJoin(e,n,i,this.bufParams.getMitreLimit())},addFilletCorner:function(t,e,n,i,r){var s=e.x-t.x,o=e.y-t.y,a=Math.atan2(o,s),u=n.x-t.x,l=n.y-t.y,h=Math.atan2(l,u);i===he.CLOCKWISE?a<=h&&(a+=2*Math.PI):a>=h&&(a-=2*Math.PI),this.segList.addPt(e),this.addFilletArc(t,a,h,i,r),this.segList.addPt(n)},addOutsideTurn:function(t,e){return this.offset0.p1.distance(this.offset1.p0)0){var n=new g((this.closingSegLengthFactor*this.offset0.p1.x+this.s1.x)/(this.closingSegLengthFactor+1),(this.closingSegLengthFactor*this.offset0.p1.y+this.s1.y)/(this.closingSegLengthFactor+1));this.segList.addPt(n);var i=new g((this.closingSegLengthFactor*this.offset1.p0.x+this.s1.x)/(this.closingSegLengthFactor+1),(this.closingSegLengthFactor*this.offset1.p0.y+this.s1.y)/(this.closingSegLengthFactor+1));this.segList.addPt(i)}else this.segList.addPt(this.s1);this.segList.addPt(this.offset1.p0)}},createCircle:function(t){var e=new g(t.x+this.distance,t.y);this.segList.addPt(e),this.addFilletArc(t,0,2*Math.PI,-1,this.distance),this.segList.closeRing()},addBevelJoin:function(t,e){this.segList.addPt(t.p1),this.segList.addPt(e.p0)},init:function(t){this.distance=t,this.maxCurveSegmentError=t*(1-Math.cos(this.filletAngleQuantum/2)),this.segList=new tr,this.segList.setPrecisionModel(this.precisionModel),this.segList.setMinimumVertexDistance(t*er.CURVE_VERTEX_SNAP_DISTANCE_FACTOR)},addCollinear:function(t){this.li.computeIntersection(this.s0,this.s1,this.s1,this.s2);var e=this.li.getIntersectionNum();e>=2&&(this.bufParams.getJoinStyle()===Ki.JOIN_BEVEL||this.bufParams.getJoinStyle()===Ki.JOIN_MITRE?(t&&this.segList.addPt(this.offset0.p1),this.segList.addPt(this.offset1.p0)):this.addFilletCorner(this.s1,this.offset0.p1,this.offset1.p0,he.CLOCKWISE,this.distance))},closeRing:function(){this.segList.closeRing()},hasNarrowConcaveAngle:function(){return this._hasNarrowConcaveAngle},interfaces_:function(){return[]},getClass:function(){return er}}),er.OFFSET_SEGMENT_SEPARATION_FACTOR=.001,er.INSIDE_TURN_VERTEX_SNAP_DISTANCE_FACTOR=.001,er.CURVE_VERTEX_SNAP_DISTANCE_FACTOR=1e-6,er.MAX_CLOSING_SEG_LEN_FACTOR=80,e(nr.prototype,{getOffsetCurve:function(t,e){if(this.distance=e,0===e)return null;var n=e<0,i=Math.abs(e),r=this.getSegGen(i);t.length<=1?this.computePointCurve(t[0],r):this.computeOffsetCurve(t,n,r);var s=r.getCoordinates();return n&&H.reverse(s),s},computeSingleSidedBufferCurve:function(t,e,n){var i=this.simplifyTolerance(this.distance);if(e){n.addSegments(t,!0);var r=$i.simplify(t,-i),s=r.length-1;n.initSideSegments(r[s],r[s-1],cn.LEFT),n.addFirstSegment();for(var o=s-2;o>=0;o--)n.addNextSegment(r[o],!0)}else{n.addSegments(t,!1);var a=$i.simplify(t,i),u=a.length-1;n.initSideSegments(a[0],a[1],cn.LEFT),n.addFirstSegment();for(var o=2;o<=u;o++)n.addNextSegment(a[o],!0)}n.addLastSegment(),n.closeRing()},computeRingBufferCurve:function(t,e,n){var i=this.simplifyTolerance(this.distance);e===cn.RIGHT&&(i=-i);var r=$i.simplify(t,i),s=r.length-1;n.initSideSegments(r[s-1],r[0],e);for(var o=1;o<=s;o++){var a=1!==o;n.addNextSegment(r[o],a)}n.closeRing()},computeLineBufferCurve:function(t,e){var n=this.simplifyTolerance(this.distance),i=$i.simplify(t,n),r=i.length-1;e.initSideSegments(i[0],i[1],cn.LEFT);for(var s=2;s<=r;s++)e.addNextSegment(i[s],!0);e.addLastSegment(),e.addLineEndCap(i[r-1],i[r]);var o=$i.simplify(t,-n),a=o.length-1;e.initSideSegments(o[a],o[a-1],cn.LEFT);for(var s=a-2;s>=0;s--)e.addNextSegment(o[s],!0);e.addLastSegment(),e.addLineEndCap(o[1],o[0]),e.closeRing()},computePointCurve:function(t,e){switch(this.bufParams.getEndCapStyle()){case Ki.CAP_ROUND:e.createCircle(t);break;case Ki.CAP_SQUARE:e.createSquare(t)}},getLineCurve:function(t,e){if(this.distance=e,e<0&&!this.bufParams.isSingleSided())return null;if(0===e)return null;var n=Math.abs(e),i=this.getSegGen(n);if(t.length<=1)this.computePointCurve(t[0],i);else if(this.bufParams.isSingleSided()){var r=e<0;this.computeSingleSidedBufferCurve(t,r,i)}else this.computeLineBufferCurve(t,i);var s=i.getCoordinates();return s},getBufferParameters:function(){return this.bufParams},simplifyTolerance:function(t){return t*this.bufParams.getSimplifyFactor()},getRingCurve:function(t,e,n){if(this.distance=n,t.length<=2)return this.getLineCurve(t,n);if(0===n)return nr.copyCoordinates(t);var i=this.getSegGen(n);return this.computeRingBufferCurve(t,e,i),i.getCoordinates()},computeOffsetCurve:function(t,e,n){var i=this.simplifyTolerance(this.distance);if(e){var r=$i.simplify(t,-i),s=r.length-1;n.initSideSegments(r[s],r[s-1],cn.LEFT),n.addFirstSegment();for(var o=s-2;o>=0;o--)n.addNextSegment(r[o],!0)}else{var a=$i.simplify(t,i),u=a.length-1;n.initSideSegments(a[0],a[1],cn.LEFT),n.addFirstSegment();for(var o=2;o<=u;o++)n.addNextSegment(a[o],!0)}n.addLastSegment()},getSegGen:function(t){return new er(this.precisionModel,this.bufParams,t)},interfaces_:function(){return[]},getClass:function(){return nr}}),nr.copyCoordinates=function(t){for(var e=new Array(t.length).fill(null),n=0;nr.getMaxY()||this.findStabbedSegments(t,i.getDirectedEdges(),e)}return e}if(3===arguments.length)if(R(arguments[2],y)&&arguments[0]instanceof g&&arguments[1]instanceof In)for(var s=arguments[0],o=arguments[1],a=arguments[2],u=o.getEdge().getCoordinates(),n=0;nthis.seg.p1.y&&this.seg.reverse();var l=Math.max(this.seg.p0.x,this.seg.p1.x);if(!(lthis.seg.p1.y||he.computeOrientation(this.seg.p0,this.seg.p1,s)===he.RIGHT)){var h=o.getDepth(cn.LEFT);this.seg.p0.equals(u[n])||(h=o.getDepth(cn.RIGHT));var c=new rr(this.seg,h);a.add(c)}}else if(R(arguments[2],y)&&arguments[0]instanceof g&&R(arguments[1],y))for(var f=arguments[0],d=arguments[1],p=arguments[2],n=d.iterator();n.hasNext();){var v=n.next();v.isForward()&&this.findStabbedSegments(f,v,p)}},getDepth:function(t){var e=this.findStabbedSegments(t);if(0===e.size())return 0;var n=ho.min(e);return n.leftDepth},interfaces_:function(){return[]},getClass:function(){return ir}}),e(rr.prototype,{compareTo:function(t){var e=t;if(this.upwardSeg.minX()>=e.upwardSeg.maxX())return 1;if(this.upwardSeg.maxX()<=e.upwardSeg.minX())return-1;var n=this.upwardSeg.orientationIndex(e.upwardSeg);return 0!==n?n:(n=-1*e.upwardSeg.orientationIndex(this.upwardSeg),0!==n?n:this.upwardSeg.compareTo(e.upwardSeg))},compareX:function(t,e){var n=t.p0.compareTo(e.p0);return 0!==n?n:t.p1.compareTo(e.p1)},toString:function(){return this.upwardSeg.toString()},interfaces_:function(){return[s]},getClass:function(){return rr}}),ir.DepthSegment=rr,e(sr.prototype,{addPoint:function(t){if(this.distance<=0)return null;var e=t.getCoordinates(),n=this.curveBuilder.getLineCurve(e,this.distance);this.addCurve(n,L.EXTERIOR,L.INTERIOR)},addPolygon:function(t){var e=this.distance,n=cn.LEFT;this.distance<0&&(e=-this.distance,n=cn.RIGHT);var i=t.getExteriorRing(),r=H.removeRepeatedPoints(i.getCoordinates());if(this.distance<0&&this.isErodedCompletely(i,this.distance))return null;if(this.distance<=0&&r.length<3)return null;this.addPolygonRing(r,e,n,L.EXTERIOR,L.INTERIOR);for(var s=0;s0&&this.isErodedCompletely(o,-this.distance)||this.addPolygonRing(a,e,cn.opposite(n),L.INTERIOR,L.EXTERIOR)}},isTriangleErodedCompletely:function(t,e){var n=new Si(t[0],t[1],t[2]),i=n.inCentre(),r=he.distancePointLine(i,n.p0,n.p1);return r=bt.MINIMUM_VALID_SIZE&&he.isCCW(t)&&(s=r,o=i,n=cn.opposite(n));var a=this.curveBuilder.getRingCurve(t,n,e);this.addCurve(a,s,o)},add:function(t){if(t.isEmpty())return null;if(t instanceof Tt)this.addPolygon(t);else if(t instanceof St)this.addLineString(t);else if(t instanceof Lt)this.addPoint(t);else if(t instanceof Pt)this.addCollection(t);else if(t instanceof gt)this.addCollection(t);else if(t instanceof Ot)this.addCollection(t);else{if(!(t instanceof ft))throw new UnsupportedOperationException(t.getClass().getName());this.addCollection(t)}},isErodedCompletely:function(t,e){var n=t.getCoordinates();if(n.length<4)return e<0;if(4===n.length)return this.isTriangleErodedCompletely(n,e);var i=t.getEnvelopeInternal(),r=Math.min(i.getHeight(),i.getWidth());return e<0&&2*Math.abs(e)>r},addCollection:function(t){for(var e=0;ei||this.maxys;if(o)return!1;var a=this.intersectsToleranceSquare(t,e);return f.isTrue(!(o&&a),\"Found bad envelope test\"),a},initCorners:function(t){var e=.5;this.minx=t.x-e,this.maxx=t.x+e,this.miny=t.y-e,this.maxy=t.y+e,this.corner[0]=new g(this.maxx,this.maxy),this.corner[1]=new g(this.minx,this.maxy),this.corner[2]=new g(this.minx,this.miny),this.corner[3]=new g(this.maxx,this.miny)},intersects:function(t,e){return 1===this.scaleFactor?this.intersectsScaled(t,e):(this.copyScaled(t,this.p0Scaled),this.copyScaled(e,this.p1Scaled),this.intersectsScaled(this.p0Scaled,this.p1Scaled))},scale:function(t){return Math.round(t*this.scaleFactor)},getCoordinate:function(){return this.originalPt},copyScaled:function(t,e){e.x=this.scale(t.x),e.y=this.scale(t.y)},getSafeEnvelope:function(){if(null===this.safeEnv){var t=lr.SAFE_ENV_EXPANSION_FACTOR/this.scaleFactor;this.safeEnv=new C(this.originalPt.x-t,this.originalPt.x+t,this.originalPt.y-t,this.originalPt.y+t)}return this.safeEnv},intersectsPixelClosure:function(t,e){return this.li.computeIntersection(t,e,this.corner[0],this.corner[1]),!!this.li.hasIntersection()||(this.li.computeIntersection(t,e,this.corner[1],this.corner[2]),!!this.li.hasIntersection()||(this.li.computeIntersection(t,e,this.corner[2],this.corner[3]),!!this.li.hasIntersection()||(this.li.computeIntersection(t,e,this.corner[3],this.corner[0]),!!this.li.hasIntersection())))},intersectsToleranceSquare:function(t,e){var n=!1,i=!1;return this.li.computeIntersection(t,e,this.corner[0],this.corner[1]),!!this.li.isProper()||(this.li.computeIntersection(t,e,this.corner[1],this.corner[2]),!!this.li.isProper()||(this.li.hasIntersection()&&(n=!0),this.li.computeIntersection(t,e,this.corner[2],this.corner[3]),!!this.li.isProper()||(this.li.hasIntersection()&&(i=!0),this.li.computeIntersection(t,e,this.corner[3],this.corner[0]),!!this.li.isProper()||(!(!n||!i)||(!!t.equals(this.pt)||!!e.equals(this.pt))))))},addSnappedNode:function(t,e){var n=t.getCoordinate(e),i=t.getCoordinate(e+1);return!!this.intersects(n,i)&&(t.addIntersection(this.getCoordinate(),e),!0)},interfaces_:function(){return[]},getClass:function(){return lr}}),lr.SAFE_ENV_EXPANSION_FACTOR=.75,e(hr.prototype,{snap:function(){if(1===arguments.length){var t=arguments[0];return this.snap(t,null,-1)}if(3===arguments.length){var e=arguments[0],n=arguments[1],i=arguments[2],r=e.getSafeEnvelope(),s=new cr(e,n,i);return this.index.query(r,{interfaces_:function(){return[Ae]},visitItem:function(t){var e=t;e.select(r,s)}}),s.isNodeAdded()}},interfaces_:function(){return[]},getClass:function(){return hr}}),h(cr,hi),e(cr.prototype,{isNodeAdded:function(){return this._isNodeAdded},select:function(){if(2!==arguments.length)return hi.prototype.select.apply(this,arguments);var t=arguments[0],e=arguments[1],n=t.getContext();return null!==this.parentEdge&&n===this.parentEdge&&e===this.hotPixelVertexIndex?null:void(this._isNodeAdded=this.hotPixel.addSnappedNode(n,e))},interfaces_:function(){return[]},getClass:function(){return cr}}),hr.HotPixelSnapAction=cr,e(fr.prototype,{processIntersections:function(t,e,n,i){if(t===n&&e===i)return null;var r=t.getCoordinates()[e],s=t.getCoordinates()[e+1],o=n.getCoordinates()[i],a=n.getCoordinates()[i+1];if(this.li.computeIntersection(r,s,o,a),this.li.hasIntersection()&&this.li.isInteriorIntersection()){for(var u=0;u=0;t--){try{this.bufferReducedPrecision(t)}catch(t){if(!(t instanceof sn))throw t;this.saveException=t}finally{}if(null!==this.resultGeometry)return null}throw this.saveException}if(1===arguments.length){var e=arguments[0],n=dr.precisionScaleFactor(this.argGeom,this.distance,e),i=new ee(n);this.bufferFixedPrecision(i)}},computeGeometry:function(){if(this.bufferOriginalPrecision(),null!==this.resultGeometry)return null;var t=this.argGeom.getFactory().getPrecisionModel();t.getType()===ee.FIXED?this.bufferFixedPrecision(t):this.bufferReducedPrecision()},setQuadrantSegments:function(t){this.bufParams.setQuadrantSegments(t)},bufferOriginalPrecision:function(){try{var t=new ar(this.bufParams);this.resultGeometry=t.buffer(this.argGeom,this.distance)}catch(t){if(!(t instanceof l))throw t;this.saveException=t}finally{}},getResultGeometry:function(t){return this.distance=t,this.computeGeometry(),this.resultGeometry},setEndCapStyle:function(t){this.bufParams.setEndCapStyle(t)},interfaces_:function(){return[]},getClass:function(){return dr}}),dr.bufferOp=function(){if(2===arguments.length){var t=arguments[0],e=arguments[1],n=new dr(t),i=n.getResultGeometry(e);return i}if(3===arguments.length){if(Number.isInteger(arguments[2])&&arguments[0]instanceof B&&\"number\"==typeof arguments[1]){var r=arguments[0],s=arguments[1],o=arguments[2],a=new dr(r);a.setQuadrantSegments(o);var i=a.getResultGeometry(s);return i}if(arguments[2]instanceof Ki&&arguments[0]instanceof B&&\"number\"==typeof arguments[1]){var u=arguments[0],l=arguments[1],h=arguments[2],a=new dr(u,h),i=a.getResultGeometry(l);return i}}else if(4===arguments.length){var c=arguments[0],f=arguments[1],g=arguments[2],d=arguments[3],a=new dr(c);a.setQuadrantSegments(g),a.setEndCapStyle(d);var i=a.getResultGeometry(f);return i}},dr.precisionScaleFactor=function(t,e,n){var i=t.getEnvelopeInternal(),r=T.max(Math.abs(i.getMaxX()),Math.abs(i.getMaxY()),Math.abs(i.getMinX()),Math.abs(i.getMinY())),s=e>0?e:0,o=r+2*s,a=Math.trunc(Math.log(o)/Math.log(10)+1),u=n-a,l=Math.pow(10,u);return l},dr.CAP_ROUND=Ki.CAP_ROUND,dr.CAP_BUTT=Ki.CAP_FLAT,dr.CAP_FLAT=Ki.CAP_FLAT,dr.CAP_SQUARE=Ki.CAP_SQUARE,dr.MAX_PRECISION_DIGITS=12;var So=Object.freeze({BufferOp:dr,BufferParameters:Ki});e(pr.prototype,{filter:function(t){t instanceof Tt&&this.comps.add(t)},interfaces_:function(){return[ht]},getClass:function(){return pr}}),pr.getPolygons=function(){if(1===arguments.length){var t=arguments[0];return pr.getPolygons(t,new I)}if(2===arguments.length){var e=arguments[0],n=arguments[1];return e instanceof Tt?n.add(e):e instanceof ft&&e.apply(new pr(n)),n}},e(vr.prototype,{isInsideArea:function(){return this.segIndex===vr.INSIDE_AREA},getCoordinate:function(){return this.pt},getGeometryComponent:function(){return this.component},getSegmentIndex:function(){return this.segIndex},interfaces_:function(){return[]},getClass:function(){return vr}}),vr.INSIDE_AREA=-1,e(mr.prototype,{filter:function(t){t instanceof Lt&&this.pts.add(t)},interfaces_:function(){return[ht]},getClass:function(){return mr}}),mr.getPoints=function(){if(1===arguments.length){var t=arguments[0];return t instanceof Lt?ho.singletonList(t):mr.getPoints(t,new I)}if(2===arguments.length){var e=arguments[0],n=arguments[1];return e instanceof Lt?n.add(e):e instanceof ft&&e.apply(new mr(n)),n}},e(yr.prototype,{filter:function(t){(t instanceof Lt||t instanceof St||t instanceof Tt)&&this.locations.add(new vr(t,0,t.getCoordinate()))},interfaces_:function(){return[ht]},getClass:function(){return yr}}),yr.getLocations=function(t){var e=new I;return t.apply(new yr(e)),e},e(xr.prototype,{computeContainmentDistance:function(){if(0===arguments.length){var t=new Array(2).fill(null);if(this.computeContainmentDistance(0,t),this.minDistance<=this.terminateDistance)return null;this.computeContainmentDistance(1,t)}else if(2===arguments.length){var e=arguments[0],n=arguments[1],i=1-e,r=pr.getPolygons(this.geom[e]);if(r.size()>0){var s=yr.getLocations(this.geom[i]);if(this.computeContainmentDistance(s,r,n),this.minDistance<=this.terminateDistance)return this.minDistanceLocation[i]=n[0],this.minDistanceLocation[e]=n[1],null}}else if(3===arguments.length)if(arguments[2]instanceof Array&&R(arguments[0],y)&&R(arguments[1],y)){for(var o=arguments[0],a=arguments[1],u=arguments[2],l=0;lthis.minDistance)return null;for(var i=t.getCoordinates(),r=e.getCoordinate(),s=0;sthis.minDistance)return null;for(var i=l.getCoordinates(),f=h.getCoordinates(),s=0;st&&H.reverse(this.coordinates)}return this.coordinates},toLineString:function(){return this.factory.createLineString(this.getCoordinates())},add:function(t){this.directedEdges.add(t)},interfaces_:function(){return[]},getClass:function(){return Er}}),e(Ir.prototype,{setVisited:function(t){this._isVisited=t},isMarked:function(){return this._isMarked},setData:function(t){this.data=t},getData:function(){return this.data},setMarked:function(t){this._isMarked=t},getContext:function(){return this.data},isVisited:function(){return this._isVisited},setContext:function(t){this.data=t},interfaces_:function(){return[]},getClass:function(){return Ir}}),Ir.getComponentWithVisitedState=function(t,e){for(;t.hasNext();){var n=t.next();if(n.isVisited()===e)return n}return null},Ir.setVisited=function(t,e){for(;t.hasNext();){var n=t.next();n.setVisited(e)}},Ir.setMarked=function(t,e){for(;t.hasNext();){var n=t.next();n.setMarked(e)}},h(Nr,Ir),e(Nr.prototype,{isRemoved:function(){return null===this.parentEdge},compareDirection:function(t){return this.quadrant>t.quadrant?1:this.quadrant=t.getNumPoints()&&null===i)return null;var s=t.getCoordinate(r);null!==i&&i.segmentIndex===n.segmentIndex&&(s=i.coord);var o=new En(t,n.coord,s,new gn(t.getLabel()));e.add(o)},createEdgeEndForPrev:function(t,e,n,i){var r=n.segmentIndex;if(0===n.dist){if(0===r)return null;r--}var s=t.getCoordinate(r);null!==i&&i.segmentIndex>=r&&(s=i.coord);var o=new gn(t.getLabel());o.flip();var a=new En(t,n.coord,s,o);e.add(a)},computeEdgeEnds:function(){if(1===arguments.length){for(var t=arguments[0],e=new I,n=t;n.hasNext();){var i=n.next();this.computeEdgeEnds(i,e)}return e}if(2===arguments.length){var r=arguments[0],s=arguments[1],o=r.getEdgeIntersectionList();o.addEndpoints();var a=o.iterator(),u=null,l=null;if(!a.hasNext())return null;var h=a.next();do u=l,l=h,h=null,a.hasNext()&&(h=a.next()),null!==l&&(this.createEdgeEndForPrev(r,s,l,u),this.createEdgeEndForNext(r,s,l,h));while(null!==l)}},interfaces_:function(){return[]},getClass:function(){return Ar}}),h(Fr,En),e(Fr.prototype,{insert:function(t){this.edgeEnds.add(t)},print:function(t){t.println(\"EdgeEndBundle--> Label: \"+this.label);for(var e=this.iterator();e.hasNext();){var n=e.next();n.print(t),t.println()}},iterator:function(){return this.edgeEnds.iterator()},getEdgeEnds:function(){return this.edgeEnds},computeLabelOn:function(t,e){for(var n=0,i=!1,r=this.iterator();r.hasNext();){var s=r.next(),o=s.getLabel().getLocation(t);o===L.BOUNDARY&&n++,o===L.INTERIOR&&(i=!0)}var o=L.NONE;i&&(o=L.INTERIOR),n>0&&(o=$n.determineBoundary(e,n)),this.label.setLocation(t,o)},computeLabelSide:function(t,e){for(var n=this.iterator();n.hasNext();){var i=n.next();if(i.getLabel().isArea()){var r=i.getLabel().getLocation(t,e);if(r===L.INTERIOR)return this.label.setLocation(t,e,L.INTERIOR),null;r===L.EXTERIOR&&this.label.setLocation(t,e,L.EXTERIOR)}}},getLabel:function(){return this.label},computeLabelSides:function(t){this.computeLabelSide(t,cn.LEFT),this.computeLabelSide(t,cn.RIGHT)},updateIM:function(t){Jn.updateIM(this.label,t)},computeLabel:function(t){for(var e=!1,n=this.iterator();n.hasNext();){var i=n.next();i.getLabel().isArea()&&(e=!0)}e?this.label=new gn(L.NONE,L.NONE,L.NONE):this.label=new gn(L.NONE);for(var r=0;r<2;r++)this.computeLabelOn(r,t),e&&this.computeLabelSides(r)},interfaces_:function(){return[]},getClass:function(){return Fr}}),h(Gr,Pn),e(Gr.prototype,{updateIM:function(t){for(var e=this.iterator();e.hasNext();){var n=e.next();n.updateIM(t)}},insert:function(t){var e=this.edgeMap.get(t);null===e?(e=new Fr(t),this.insertEdgeEnd(t,e)):e.insert(t)},interfaces_:function(){return[]},getClass:function(){return Gr}}),h(qr,yn),e(qr.prototype,{updateIMFromEdges:function(t){this.edges.updateIM(t)},computeIM:function(t){t.setAtLeastIfValid(this.label.getLocation(0),this.label.getLocation(1),0)},interfaces_:function(){return[]},getClass:function(){return qr}}),h(Br,Nn),e(Br.prototype,{createNode:function(t){return new qr(t,new Gr)},interfaces_:function(){return[]},getClass:function(){return Br}}),e(zr.prototype,{insertEdgeEnds:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next();this.nodes.add(n)}},getNodeIterator:function(){return this.nodes.iterator()},copyNodesAndLabels:function(t,e){for(var n=t.getNodeIterator();n.hasNext();){var i=n.next(),r=this.nodes.addNode(i.getCoordinate());r.setLabel(e,i.getLabel().getLocation(e))}},build:function(t){this.computeIntersectionNodes(t,0),this.copyNodesAndLabels(t,0);var e=new Ar,n=e.computeEdgeEnds(t.getEdgeIterator());this.insertEdgeEnds(n)},computeIntersectionNodes:function(t,e){for(var n=t.getEdgeIterator();n.hasNext();)for(var i=n.next(),r=i.getLabel().getLocation(e),s=i.getEdgeIntersectionList().iterator();s.hasNext();){var o=s.next(),a=this.nodes.addNode(o.coord);r===L.BOUNDARY?a.setLabelBoundary(e):a.getLabel().isNull(e)&&a.setLabel(e,L.INTERIOR)}},interfaces_:function(){return[]},getClass:function(){return zr}}),e(Vr.prototype,{isNodeEdgeAreaLabelsConsistent:function(){for(var t=this.nodeGraph.getNodeIterator();t.hasNext();){var e=t.next();if(!e.getEdges().isAreaLabelsConsistent(this.geomGraph))return this.invalidPoint=e.getCoordinate().copy(),!1}return!0},getInvalidPoint:function(){return this.invalidPoint},hasDuplicateRings:function(){for(var t=this.nodeGraph.getNodeIterator();t.hasNext();)for(var e=t.next(),n=e.getEdges().iterator();n.hasNext();){var i=n.next();if(i.getEdgeEnds().size()>1)return this.invalidPoint=i.getEdge().getCoordinate(0),!0}return!1},isNodeConsistentArea:function(){var t=this.geomGraph.computeSelfNodes(this.li,!0,!0);return t.hasProperIntersection()?(this.invalidPoint=t.getProperIntersectionPoint(),!1):(this.nodeGraph.build(this.geomGraph),this.isNodeEdgeAreaLabelsConsistent())},interfaces_:function(){return[]},getClass:function(){return Vr}}),e(kr.prototype,{buildIndex:function(){this.index=new ke;for(var t=0;t=1&&(e=t.getCoordinateN(0)),this.validErr=new Yr(Yr.RING_NOT_CLOSED,e)}},checkShellsNotNested:function(t,e){for(var n=0;n=0;i--)n.add(t[i],!1)},Xr.findEdgeRingContaining=function(t,e){for(var n=t.getRing(),i=n.getEnvelopeInternal(),r=n.getCoordinateN(0),s=null,o=null,a=e.iterator();a.hasNext();){var u=a.next(),l=u.getRing(),h=l.getEnvelopeInternal();if(!h.equals(i)&&h.contains(i)){r=H.ptNotInList(n.getCoordinates(),l.getCoordinates());var c=!1;he.isPointInRing(r,l.getCoordinates())&&(c=!0),c&&(null===s||o.contains(h))&&(s=u,o=s.getRing().getEnvelopeInternal())}}return s},e(Hr.prototype,{compare:function(t,e){var n=t,i=e;return n.getRing().getEnvelope().compareTo(i.getRing().getEnvelope())},interfaces_:function(){return[a]},getClass:function(){return Hr}}),Xr.EnvelopeComparator=Hr,h(Wr,Pr),e(Wr.prototype,{findEdgeRing:function(t){var e=new Xr(this.factory);return e.build(t),e},computeDepthParity:function(){if(0===arguments.length)for(;;){var t=null;if(null===t)return null;this.computeDepthParity(t)}else if(1===arguments.length){arguments[0]}},computeNextCWEdges:function(){for(var t=this.nodeIterator();t.hasNext();){var e=t.next();Wr.computeNextCWEdges(e)}},addEdge:function(t){if(t.isEmpty())return null;var e=H.removeRepeatedPoints(t.getCoordinates());if(e.length<2)return null;var n=e[0],i=e[e.length-1],r=this.getNode(n),s=this.getNode(i),o=new _r(r,s,e[1],(!0)),a=new _r(s,r,e[e.length-2],(!1)),u=new Mr(t);u.setDirectedEdges(o,a),this.add(u)},deleteCutEdges:function(){this.computeNextCWEdges(),Wr.findLabeledEdgeRings(this.dirEdges);for(var t=new I,e=this.dirEdges.iterator();e.hasNext();){var n=e.next();if(!n.isMarked()){var i=n.getSym();if(n.getLabel()===i.getLabel()){n.setMarked(!0),i.setMarked(!0);var r=n.getEdge();t.add(r.getLine())}}}return t},getEdgeRings:function(){this.computeNextCWEdges(),Wr.label(this.dirEdges,-1);var t=Wr.findLabeledEdgeRings(this.dirEdges);this.convertMaximalToMinimalEdgeRings(t);for(var e=new I,n=this.dirEdges.iterator();n.hasNext();){var i=n.next();if(!i.isMarked()&&!i.isInRing()){var r=this.findEdgeRing(i);e.add(r)}}return e},getNode:function(t){var e=this.findNode(t);return null===e&&(e=new Lr(t),this.add(e)),e},convertMaximalToMinimalEdgeRings:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),i=n.getLabel(),r=Wr.findIntersectionNodes(n,i);if(null!==r)for(var s=r.iterator();s.hasNext();){var o=s.next();Wr.computeNextCCWEdges(o,i)}}},deleteDangles:function(){for(var t=this.findNodesOfDegree(1),e=new J,n=new pe,i=t.iterator();i.hasNext();)n.push(i.next());for(;!n.isEmpty();){var r=n.pop();Wr.deleteAllEdges(r);for(var s=r.getOutEdges().getEdges(),i=s.iterator();i.hasNext();){var o=i.next();o.setMarked(!0);var a=o.getSym();null!==a&&a.setMarked(!0);var u=o.getEdge();e.add(u.getLine());var l=o.getToNode();1===Wr.getDegreeNonDeleted(l)&&n.push(l)}}return e},interfaces_:function(){return[]},getClass:function(){return Wr}}),Wr.findLabeledEdgeRings=function(t){for(var e=new I,n=1,i=t.iterator();i.hasNext();){var r=i.next();if(!(r.isMarked()||r.getLabel()>=0)){e.add(r);var s=Xr.findDirEdgesInRing(r);Wr.label(s,n),n++}}return e},Wr.getDegreeNonDeleted=function(t){for(var e=t.getOutEdges().getEdges(),n=0,i=e.iterator();i.hasNext();){var r=i.next();r.isMarked()||n++}return n},Wr.deleteAllEdges=function(t){for(var e=t.getOutEdges().getEdges(),n=e.iterator();n.hasNext();){var i=n.next();i.setMarked(!0);var r=i.getSym();null!==r&&r.setMarked(!0)}},Wr.label=function(t,e){for(var n=t.iterator();n.hasNext();){var i=n.next();i.setLabel(e)}},Wr.computeNextCWEdges=function(t){for(var e=t.getOutEdges(),n=null,i=null,r=e.getEdges().iterator();r.hasNext();){var s=r.next();if(!s.isMarked()){if(null===n&&(n=s),null!==i){var o=i.getSym();o.setNext(s)}i=s}}if(null!==i){var o=i.getSym();o.setNext(n)}},Wr.computeNextCCWEdges=function(t,e){for(var n=t.getOutEdges(),i=null,r=null,s=n.getEdges(),o=s.size()-1;o>=0;o--){var a=s.get(o),u=a.getSym(),l=null;a.getLabel()===e&&(l=a);var h=null;u.getLabel()===e&&(h=u),null===l&&null===h||(null!==h&&(r=h),null!==l&&(null!==r&&(r.setNext(l),r=null),null===i&&(i=l)))}null!==r&&(f.isTrue(null!==i),r.setNext(i))},Wr.getDegree=function(t,e){for(var n=t.getOutEdges().getEdges(),i=0,r=n.iterator();r.hasNext();){var s=r.next();s.getLabel()===e&&i++}return i},Wr.findIntersectionNodes=function(t,e){var n=t,i=null;do{var r=n.getFromNode();Wr.getDegree(r,e)>1&&(null===i&&(i=new I),i.add(r)),n=n.getNext(),f.isTrue(null!==n,\"found null DE in ring\"),f.isTrue(n===t||!n.isInRing(),\"found DE already in ring\")}while(n!==t);return i},e(jr.prototype,{getGeometry:function(){return null===this.geomFactory&&(this.geomFactory=new ie),this.polygonize(),this.extractOnlyPolygonal?this.geomFactory.buildGeometry(this.polyList):this.geomFactory.createGeometryCollection(ie.toGeometryArray(this.polyList))},getInvalidRingLines:function(){return this.polygonize(),this.invalidRingLines},findValidRings:function(t,e,n){for(var i=t.iterator();i.hasNext();){var r=i.next();r.isValid()?e.add(r):n.add(r.getLineString())}},polygonize:function(){if(null!==this.polyList)return null;\nif(this.polyList=new I,null===this.graph)return null;this.dangles=this.graph.deleteDangles(),this.cutEdges=this.graph.deleteCutEdges();var t=this.graph.getEdgeRings(),e=new I;this.invalidRingLines=new I,this.isCheckingRingsValid?this.findValidRings(t,e,this.invalidRingLines):e=t,this.findShellsAndHoles(e),jr.assignHolesToShells(this.holeList,this.shellList),ho.sort(this.shellList,new Xr.EnvelopeComparator);var n=!0;this.extractOnlyPolygonal&&(jr.findDisjointShells(this.shellList),n=!1),this.polyList=jr.extractPolygons(this.shellList,n)},getDangles:function(){return this.polygonize(),this.dangles},getCutEdges:function(){return this.polygonize(),this.cutEdges},getPolygons:function(){return this.polygonize(),this.polyList},add:function(){if(R(arguments[0],v))for(var t=arguments[0],e=t.iterator();e.hasNext();){var n=e.next();this.add(n)}else if(arguments[0]instanceof St){var i=arguments[0];this.geomFactory=i.getFactory(),null===this.graph&&(this.graph=new Wr(this.geomFactory)),this.graph.addEdge(i)}else if(arguments[0]instanceof B){var r=arguments[0];r.apply(this.lineStringAdder)}},setCheckRingsValid:function(t){this.isCheckingRingsValid=t},findShellsAndHoles:function(t){this.holeList=new I,this.shellList=new I;for(var e=t.iterator();e.hasNext();){var n=e.next();n.computeHole(),n.isHole()?this.holeList.add(n):this.shellList.add(n)}},interfaces_:function(){return[]},getClass:function(){return jr}}),jr.findOuterShells=function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),i=n.getOuterHole();null===i||i.isProcessed()||(n.setIncluded(!0),i.setProcessed(!0))}},jr.extractPolygons=function(t,e){for(var n=new I,i=t.iterator();i.hasNext();){var r=i.next();(e||r.isIncluded())&&n.add(r.getPolygon())}return n},jr.assignHolesToShells=function(t,e){for(var n=t.iterator();n.hasNext();){var i=n.next();jr.assignHoleToShell(i,e)}},jr.assignHoleToShell=function(t,e){var n=Xr.findEdgeRingContaining(t,e);null!==n&&n.addHole(t)},jr.findDisjointShells=function(t){jr.findOuterShells(t);var e=null;do{e=!1;for(var n=t.iterator();n.hasNext();){var i=n.next();i.isIncludedSet()||(i.updateIncluded(),i.isIncludedSet()||(e=!0))}}while(e)},e(Kr.prototype,{filter:function(t){t instanceof St&&this.p.add(t)},interfaces_:function(){return[q]},getClass:function(){return Kr}}),jr.LineStringAdder=Kr;var To=Object.freeze({Polygonizer:jr});e(Zr.prototype,{insertEdgeEnds:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next();this.nodes.add(n)}},computeProperIntersectionIM:function(t,e){var n=this.arg[0].getGeometry().getDimension(),i=this.arg[1].getGeometry().getDimension(),r=t.hasProperIntersection(),s=t.hasProperInteriorIntersection();2===n&&2===i?r&&e.setAtLeast(\"212101212\"):2===n&&1===i?(r&&e.setAtLeast(\"FFF0FFFF2\"),s&&e.setAtLeast(\"1FFFFF1FF\")):1===n&&2===i?(r&&e.setAtLeast(\"F0FFFFFF2\"),s&&e.setAtLeast(\"1F1FFFFFF\")):1===n&&1===i&&s&&e.setAtLeast(\"0FFFFFFFF\")},labelIsolatedEdges:function(t,e){for(var n=this.arg[t].getEdgeIterator();n.hasNext();){var i=n.next();i.isIsolated()&&(this.labelIsolatedEdge(i,e,this.arg[e].getGeometry()),this.isolatedEdges.add(i))}},labelIsolatedEdge:function(t,e,n){if(n.getDimension()>0){var i=this.ptLocator.locate(t.getCoordinate(),n);t.getLabel().setAllLocations(e,i)}else t.getLabel().setAllLocations(e,L.EXTERIOR)},computeIM:function(){var t=new fe;if(t.set(L.EXTERIOR,L.EXTERIOR,2),!this.arg[0].getGeometry().getEnvelopeInternal().intersects(this.arg[1].getGeometry().getEnvelopeInternal()))return this.computeDisjointIM(t),t;this.arg[0].computeSelfNodes(this.li,!1),this.arg[1].computeSelfNodes(this.li,!1);var e=this.arg[0].computeEdgeIntersections(this.arg[1],this.li,!1);this.computeIntersectionNodes(0),this.computeIntersectionNodes(1),this.copyNodesAndLabels(0),this.copyNodesAndLabels(1),this.labelIsolatedNodes(),this.computeProperIntersectionIM(e,t);var n=new Ar,i=n.computeEdgeEnds(this.arg[0].getEdgeIterator());this.insertEdgeEnds(i);var r=n.computeEdgeEnds(this.arg[1].getEdgeIterator());return this.insertEdgeEnds(r),this.labelNodeEdges(),this.labelIsolatedEdges(0,1),this.labelIsolatedEdges(1,0),this.updateIM(t),t},labelNodeEdges:function(){for(var t=this.nodes.iterator();t.hasNext();){var e=t.next();e.getEdges().computeLabelling(this.arg)}},copyNodesAndLabels:function(t){for(var e=this.arg[t].getNodeIterator();e.hasNext();){var n=e.next(),i=this.nodes.addNode(n.getCoordinate());i.setLabel(t,n.getLabel().getLocation(t))}},labelIntersectionNodes:function(t){for(var e=this.arg[t].getEdgeIterator();e.hasNext();)for(var n=e.next(),i=n.getLabel().getLocation(t),r=n.getEdgeIntersectionList().iterator();r.hasNext();){var s=r.next(),o=this.nodes.find(s.coord);o.getLabel().isNull(t)&&(i===L.BOUNDARY?o.setLabelBoundary(t):o.setLabel(t,L.INTERIOR))}},labelIsolatedNode:function(t,e){var n=this.ptLocator.locate(t.getCoordinate(),this.arg[e].getGeometry());t.getLabel().setAllLocations(e,n)},computeIntersectionNodes:function(t){for(var e=this.arg[t].getEdgeIterator();e.hasNext();)for(var n=e.next(),i=n.getLabel().getLocation(t),r=n.getEdgeIntersectionList().iterator();r.hasNext();){var s=r.next(),o=this.nodes.addNode(s.coord);i===L.BOUNDARY?o.setLabelBoundary(t):o.getLabel().isNull(t)&&o.setLabel(t,L.INTERIOR)}},labelIsolatedNodes:function(){for(var t=this.nodes.iterator();t.hasNext();){var e=t.next(),n=e.getLabel();f.isTrue(n.getGeometryCount()>0,\"node with empty label found\"),e.isIsolated()&&(n.isNull(0)?this.labelIsolatedNode(e,0):this.labelIsolatedNode(e,1))}},updateIM:function(t){for(var e=this.isolatedEdges.iterator();e.hasNext();){var n=e.next();n.updateIM(t)}for(var i=this.nodes.iterator();i.hasNext();){var r=i.next();r.updateIM(t),r.updateIMFromEdges(t)}},computeDisjointIM:function(t){var e=this.arg[0].getGeometry();e.isEmpty()||(t.set(L.INTERIOR,L.EXTERIOR,e.getDimension()),t.set(L.BOUNDARY,L.EXTERIOR,e.getBoundaryDimension()));var n=this.arg[1].getGeometry();n.isEmpty()||(t.set(L.EXTERIOR,L.INTERIOR,n.getDimension()),t.set(L.EXTERIOR,L.BOUNDARY,n.getBoundaryDimension()))},interfaces_:function(){return[]},getClass:function(){return Zr}}),e(Qr.prototype,{isContainedInBoundary:function(t){if(t instanceof Tt)return!1;if(t instanceof Lt)return this.isPointContainedInBoundary(t);if(t instanceof St)return this.isLineStringContainedInBoundary(t);for(var e=0;e0){var i=t;t=e,e=i}var r=!1;return e.y>t.y&&(r=!0),r?this.li.computeIntersection(t,e,this.diagDown0,this.diagDown1):this.li.computeIntersection(t,e,this.diagUp0,this.diagUp1),!!this.li.hasIntersection()},interfaces_:function(){return[]},getClass:function(){return Jr}}),e($r.prototype,{applyTo:function(t){for(var e=0;e=this.rectEnv.getMinX()&&e.getMaxX()<=this.rectEnv.getMaxX()?(this._intersects=!0,null):e.getMinY()>=this.rectEnv.getMinY()&&e.getMaxY()<=this.rectEnv.getMaxY()?(this._intersects=!0,null):void 0:null},intersects:function(){return this._intersects},interfaces_:function(){return[]},getClass:function(){return es}}),h(ns,$r),e(ns.prototype,{isDone:function(){return this._containsPoint===!0},visit:function(t){if(!(t instanceof Tt))return null;var e=t.getEnvelopeInternal();if(!this.rectEnv.intersects(e))return null;for(var n=new g,i=0;i<4;i++)if(this.rectSeq.getCoordinate(i,n),e.contains(n)&&Tn.containsPointInPolygon(n,t))return this._containsPoint=!0,null},containsPoint:function(){return this._containsPoint},interfaces_:function(){return[]},getClass:function(){return ns}}),h(is,$r),e(is.prototype,{intersects:function(){return this.hasIntersection},isDone:function(){return this.hasIntersection===!0},visit:function(t){var e=t.getEnvelopeInternal();if(!this.rectEnv.intersects(e))return null;var n=kn.getLines(t);this.checkIntersectionWithLineStrings(n)},checkIntersectionWithLineStrings:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next();if(this.checkIntersectionWithSegments(n),this.hasIntersection)return null}},checkIntersectionWithSegments:function(t){for(var e=t.getCoordinateSequence(),n=1;n=t.size()?null:t.get(e)},us.union=function(t){var e=new us(t);return e.union()},us.STRTREE_NODE_CAPACITY=4,e(ls.prototype,{unionNoOpt:function(t){var e=this.geomFact.createPoint();return si.overlayOp(t,e,ii.UNION)},unionWithNull:function(t,e){return null===t&&null===e?null:null===e?t:null===t?e:t.union(e)},extract:function(){if(R(arguments[0],v))for(var t=arguments[0],e=t.iterator();e.hasNext();){var n=e.next();this.extract(n)}else if(arguments[0]instanceof B){var i=arguments[0];null===this.geomFact&&(this.geomFact=i.getFactory()),as.extract(i,B.SORTINDEX_POLYGON,this.polygons),as.extract(i,B.SORTINDEX_LINESTRING,this.lines),as.extract(i,B.SORTINDEX_POINT,this.points)}},union:function t(){if(null===this.geomFact)return null;var e=null;if(this.points.size()>0){var n=this.geomFact.buildGeometry(this.points);e=this.unionNoOpt(n)}var i=null;if(this.lines.size()>0){var r=this.geomFact.buildGeometry(this.lines);i=this.unionNoOpt(r)}var s=null;this.polygons.size()>0&&(s=us.union(this.polygons));var o=this.unionWithNull(i,s),t=null;return t=null===e?o:null===o?e:os.union(e,o),null===t?this.geomFact.createGeometryCollection():t},interfaces_:function(){return[]},getClass:function(){return ls}}),ls.union=function(){if(1===arguments.length){if(R(arguments[0],v)){var t=arguments[0],e=new ls(t);return e.union()}if(arguments[0]instanceof B){var n=arguments[0],e=new ls(n);return e.union()}}else if(2===arguments.length){var i=arguments[0],r=arguments[1],e=new ls(i,r);return e.union()}};var bo=Object.freeze({UnaryUnionOp:ls}),Oo=Object.freeze({IsValidOp:Ur,ConsistentAreaTester:Vr}),_o=Object.freeze({BoundaryOp:dt,IsSimpleOp:Wi,buffer:So,distance:wo,linemerge:Lo,overlay:Ro,polygonize:To,relate:Po,union:bo,valid:Oo});h(hs,_t.CoordinateOperation),e(hs.prototype,{editCoordinates:function(t,e){if(0===t.length)return null;for(var n=new Array(t.length).fill(null),i=0;i=2&&(i=!0);var r=e.edit(t,new hs(this.targetPM,i));return r},changePM:function(t,e){var n=this.createEditor(t.getFactory(),e);return n.edit(t,new _t.NoOpGeometryOperation)},setRemoveCollapsedComponents:function(t){this.removeCollapsed=t},createFactory:function(t,e){var n=new ie(e,t.getSRID(),t.getCoordinateSequenceFactory());return n},setChangePrecisionModel:function(t){this.changePrecisionModel=t},reduce:function(t){var e=this.reducePointwise(t);return this.isPointwise?e:R(e,Rt)?e.isValid()?e:this.fixPolygonalTopology(e):e},setPointwise:function(t){this.isPointwise=t},createEditor:function(t,e){if(t.getPrecisionModel()===e)return new _t;var n=this.createFactory(t,e),i=new _t(n);return i},interfaces_:function(){return[]},getClass:function(){return cs}}),cs.reduce=function(t,e){var n=new cs(e);return n.reduce(t)},cs.reducePointwise=function(t,e){var n=new cs(e);return n.setPointwise(!0),n.reduce(t)};var Mo=Object.freeze({GeometryPrecisionReducer:cs});e(fs.prototype,{simplifySection:function(t,e){if(t+1===e)return null;this.seg.p0=this.pts[t],this.seg.p1=this.pts[e];for(var n=-1,i=t,r=t+1;rn&&(n=s,i=r)}if(n<=this.distanceTolerance)for(var r=t+1;rthis.distanceTolerance&&(s=!1);var l=new ce;if(l.p0=this.linePts[t],l.p1=this.linePts[e],i[0]=t,i[1]=e,this.hasBadIntersection(this.line,i,l)&&(s=!1),s){var r=this.flatten(t,e);return this.line.addToResult(r),null}this.simplifySection(t,u,n),this.simplifySection(u,e,n)},hasBadOutputIntersection:function(t){for(var e=this.outputIndex.query(t),n=e.iterator();n.hasNext();){var i=n.next();if(this.hasInteriorIntersection(i,t))return!0}return!1},findFurthestPoint:function(t,e,n,i){var r=new ce;r.p0=t[e],r.p1=t[n];for(var s=-1,o=e,a=e+1;as&&(s=l,o=a)}return i[0]=s,o},simplify:function(t){this.line=t,this.linePts=t.getParentCoordinates(),this.simplifySection(0,this.linePts.length-1,0)},remove:function(t,e,n){for(var i=e;i=e[0]&&ir&&(u=r),s.setMinimumLength(u),s.splitAt(o),s.getSplitPoint()},interfaces_:function(){return[ws]},getClass:function(){return Ls}}),Ls.projectedSplitPoint=function(t,e){var n=t.getLineSegment(),i=n.project(e);return i},e(Rs.prototype,{interfaces_:function(){return[]},getClass:function(){return Rs}}),Rs.triArea=function(t,e,n){return(e.x-t.x)*(n.y-t.y)-(e.y-t.y)*(n.x-t.x)},Rs.isInCircleDDNormalized=function(t,e,n,i){var r=_.valueOf(t.x).selfSubtract(i.x),s=_.valueOf(t.y).selfSubtract(i.y),o=_.valueOf(e.x).selfSubtract(i.x),a=_.valueOf(e.y).selfSubtract(i.y),u=_.valueOf(n.x).selfSubtract(i.x),l=_.valueOf(n.y).selfSubtract(i.y),h=r.multiply(a).selfSubtract(o.multiply(s)),c=o.multiply(l).selfSubtract(u.multiply(a)),f=u.multiply(s).selfSubtract(r.multiply(l)),g=r.multiply(r).selfAdd(s.multiply(s)),d=o.multiply(o).selfAdd(a.multiply(a)),p=u.multiply(u).selfAdd(l.multiply(l)),v=g.selfMultiply(c).selfAdd(d.selfMultiply(f)).selfAdd(p.selfMultiply(h)),m=v.doubleValue()>0;return m},Rs.checkRobustInCircle=function(t,e,n,i){var r=Rs.isInCircleNonRobust(t,e,n,i),s=Rs.isInCircleDDSlow(t,e,n,i),o=Rs.isInCircleCC(t,e,n,i),a=Si.circumcentre(t,e,n);A.out.println(\"p radius diff a = \"+Math.abs(i.distance(a)-t.distance(a))/t.distance(a)),r===s&&r===o||(A.out.println(\"inCircle robustness failure (double result = \"+r+\", DD result = \"+s+\", CC result = \"+o+\")\"),A.out.println(se.toLineString(new Gt([t,e,n,i]))),A.out.println(\"Circumcentre = \"+se.toPoint(a)+\" radius = \"+t.distance(a)),A.out.println(\"p radius diff a = \"+Math.abs(i.distance(a)/t.distance(a)-1)),A.out.println(\"p radius diff b = \"+Math.abs(i.distance(a)/e.distance(a)-1)),A.out.println(\"p radius diff c = \"+Math.abs(i.distance(a)/n.distance(a)-1)),A.out.println())},Rs.isInCircleDDFast=function(t,e,n,i){var r=_.sqr(t.x).selfAdd(_.sqr(t.y)).selfMultiply(Rs.triAreaDDFast(e,n,i)),s=_.sqr(e.x).selfAdd(_.sqr(e.y)).selfMultiply(Rs.triAreaDDFast(t,n,i)),o=_.sqr(n.x).selfAdd(_.sqr(n.y)).selfMultiply(Rs.triAreaDDFast(t,e,i)),a=_.sqr(i.x).selfAdd(_.sqr(i.y)).selfMultiply(Rs.triAreaDDFast(t,e,n)),u=r.selfSubtract(s).selfAdd(o).selfSubtract(a),l=u.doubleValue()>0;return l},Rs.isInCircleCC=function(t,e,n,i){var r=Si.circumcentre(t,e,n),s=t.distance(r),o=i.distance(r)-s;return o<=0},Rs.isInCircleNormalized=function(t,e,n,i){var r=t.x-i.x,s=t.y-i.y,o=e.x-i.x,a=e.y-i.y,u=n.x-i.x,l=n.y-i.y,h=r*a-o*s,c=o*l-u*a,f=u*s-r*l,g=r*r+s*s,d=o*o+a*a,p=u*u+l*l,v=g*c+d*f+p*h;\nreturn v>0},Rs.isInCircleDDSlow=function(t,e,n,i){var r=_.valueOf(i.x),s=_.valueOf(i.y),o=_.valueOf(t.x),a=_.valueOf(t.y),u=_.valueOf(e.x),l=_.valueOf(e.y),h=_.valueOf(n.x),c=_.valueOf(n.y),f=o.multiply(o).add(a.multiply(a)).multiply(Rs.triAreaDDSlow(u,l,h,c,r,s)),g=u.multiply(u).add(l.multiply(l)).multiply(Rs.triAreaDDSlow(o,a,h,c,r,s)),d=h.multiply(h).add(c.multiply(c)).multiply(Rs.triAreaDDSlow(o,a,u,l,r,s)),p=r.multiply(r).add(s.multiply(s)).multiply(Rs.triAreaDDSlow(o,a,u,l,h,c)),v=f.subtract(g).add(d).subtract(p),m=v.doubleValue()>0;return m},Rs.isInCircleNonRobust=function(t,e,n,i){var r=(t.x*t.x+t.y*t.y)*Rs.triArea(e,n,i)-(e.x*e.x+e.y*e.y)*Rs.triArea(t,n,i)+(n.x*n.x+n.y*n.y)*Rs.triArea(t,e,i)-(i.x*i.x+i.y*i.y)*Rs.triArea(t,e,n)>0;return r},Rs.isInCircleRobust=function(t,e,n,i){return Rs.isInCircleNormalized(t,e,n,i)},Rs.triAreaDDSlow=function(t,e,n,i,r,s){return n.subtract(t).multiply(s.subtract(e)).subtract(i.subtract(e).multiply(r.subtract(t)))},Rs.triAreaDDFast=function(t,e,n){var i=_.valueOf(e.x).selfSubtract(t.x).selfMultiply(_.valueOf(n.y).selfSubtract(t.y)),r=_.valueOf(e.y).selfSubtract(t.y).selfMultiply(_.valueOf(n.x).selfSubtract(t.x));return i.selfSubtract(r)},e(Ts.prototype,{circleCenter:function(t,e){var n=new Ts(this.getX(),this.getY()),i=this.bisector(n,t),r=this.bisector(t,e),s=new F(i,r),o=null;try{o=new Ts(s.getX(),s.getY())}catch(i){if(!(i instanceof w))throw i;A.err.println(\"a: \"+n+\" b: \"+t+\" c: \"+e),A.err.println(i)}finally{}return o},dot:function(t){return this.p.x*t.getX()+this.p.y*t.getY()},magn:function(){return Math.sqrt(this.p.x*this.p.x+this.p.y*this.p.y)},getZ:function(){return this.p.z},bisector:function(t,e){var n=e.getX()-t.getX(),i=e.getY()-t.getY(),r=new F(t.getX()+n/2,t.getY()+i/2,1),s=new F(t.getX()-i+n/2,t.getY()+n+i/2,1);return new F(r,s)},equals:function(){if(1===arguments.length){var t=arguments[0];return this.p.x===t.getX()&&this.p.y===t.getY()}if(2===arguments.length){var e=arguments[0],n=arguments[1];return this.p.distance(e.getCoordinate())0},getX:function(){return this.p.x},crossProduct:function(t){return this.p.x*t.getY()-this.p.y*t.getX()},setZ:function(t){this.p.z=t},times:function(t){return new Ts(t*this.p.x,t*this.p.y)},cross:function(){return new Ts(this.p.y,(-this.p.x))},leftOf:function(t){return this.isCCW(t.orig(),t.dest())},toString:function(){return\"POINT (\"+this.p.x+\" \"+this.p.y+\")\"},sub:function(t){return new Ts(this.p.x-t.getX(),this.p.y-t.getY())},getY:function(){return this.p.y},classify:function(t,e){var n=this,i=e.sub(t),r=n.sub(t),s=i.crossProduct(r);return s>0?Ts.LEFT:s<0?Ts.RIGHT:i.getX()*r.getX()<0||i.getY()*r.getY()<0?Ts.BEHIND:i.magn()n?10*e:10*n,this.frameVertex[0]=new Ts((t.getMaxX()+t.getMinX())/2,t.getMaxY()+i),this.frameVertex[1]=new Ts(t.getMinX()-i,t.getMinY()-i),this.frameVertex[2]=new Ts(t.getMaxX()+i,t.getMinY()-i),this.frameEnv=new C(this.frameVertex[0].getCoordinate(),this.frameVertex[1].getCoordinate()),this.frameEnv.expandToInclude(this.frameVertex[2].getCoordinate())},getTriangleCoordinates:function(t){var e=new zs;return this.visitTriangles(e,t),e.getTriangles()},getVertices:function(t){for(var e=new J,n=this.quadEdges.iterator();n.hasNext();){var i=n.next(),r=i.orig();!t&&this.isFrameVertex(r)||e.add(r);var s=i.dest();!t&&this.isFrameVertex(s)||e.add(s)}return e},fetchTriangleToVisit:function(t,e,n,i){var r=t,s=0,o=!1;do{this.triEdges[s]=r,this.isFrameEdge(r)&&(o=!0);var a=r.sym();i.contains(a)||e.push(a),i.add(r),s++,r=r.lNext()}while(r!==t);return o&&!n?null:this.triEdges},getEdges:function(){if(0===arguments.length)return this.quadEdges;if(1===arguments.length){for(var t=arguments[0],e=this.getPrimaryEdges(!1),n=new Array(e.size()).fill(null),i=0,r=e.iterator();r.hasNext();){var s=r.next();n[i++]=t.createLineString([s.orig().getCoordinate(),s.dest().getCoordinate()])}return t.createMultiLineString(n)}},getVertexUniqueEdges:function(t){for(var e=new I,n=new J,i=this.quadEdges.iterator();i.hasNext();){var r=i.next(),s=r.orig();n.contains(s)||(n.add(s),!t&&this.isFrameVertex(s)||e.add(r));var o=r.sym(),a=o.orig();n.contains(a)||(n.add(a),!t&&this.isFrameVertex(a)||e.add(o))}return e},getTriangleEdges:function(t){var e=new qs;return this.visitTriangles(e,t),e.getTriangleEdges()},getPrimaryEdges:function(t){this.visitedKey++;var e=new I,n=new pe;n.push(this.startingEdge);for(var i=new J;!n.empty();){var r=n.pop();if(!i.contains(r)){var s=r.getPrimary();!t&&this.isFrameEdge(s)||e.add(s),n.push(r.oNext()),n.push(r.sym().oNext()),i.add(r),i.add(r.sym())}}return e},delete:function(t){bs.splice(t,t.oPrev()),bs.splice(t.sym(),t.sym().oPrev());var e=t.sym(),n=t.rot(),i=t.rot().sym();this.quadEdges.remove(t),this.quadEdges.remove(e),this.quadEdges.remove(n),this.quadEdges.remove(i),t.delete(),e.delete(),n.delete(),i.delete()},locateFromEdge:function(t,e){for(var n=0,i=this.quadEdges.size(),r=e;;){if(n++,n>i)throw new Ds(r.toLineSegment());if(t.equals(r.orig())||t.equals(r.dest()))break;if(t.rightOf(r))r=r.sym();else if(t.rightOf(r.oNext())){if(t.rightOf(r.dPrev()))break;r=r.dPrev()}else r=r.oNext()}return r},getTolerance:function(){return this.tolerance},getVoronoiCellPolygons:function(t){this.visitTriangles(new Gs,!0);for(var e=new I,n=this.getVertexUniqueEdges(!1),i=n.iterator();i.hasNext();){var r=i.next();e.add(this.getVoronoiCellPolygon(r,t))}return e},getVoronoiDiagram:function(t){var e=this.getVoronoiCellPolygons(t);return t.createGeometryCollection(ie.toGeometryArray(e))},getTriangles:function(t){for(var e=this.getTriangleCoordinates(!1),n=new Array(e.size()).fill(null),i=0,r=e.iterator();r.hasNext();){var s=r.next();n[i++]=t.createPolygon(t.createLinearRing(s),null)}return t.createGeometryCollection(n)},insertSite:function(t){var e=this.locate(t);if(t.equals(e.orig(),this.tolerance)||t.equals(e.dest(),this.tolerance))return e;var n=this.makeEdge(e.orig(),t);bs.splice(n,e);var i=n;do n=this.connect(e,n.sym()),e=n.oPrev();while(e.lNext()!==i);return i},locate:function(){if(1===arguments.length){if(arguments[0]instanceof Ts){var t=arguments[0];return this.locator.locate(t)}if(arguments[0]instanceof g){var e=arguments[0];return this.locator.locate(new Ts(e))}}else if(2===arguments.length){var n=arguments[0],i=arguments[1],r=this.locator.locate(new Ts(n));if(null===r)return null;var s=r;r.dest().getCoordinate().equals2D(n)&&(s=r.sym());var o=s;do{if(o.dest().getCoordinate().equals2D(i))return o;o=o.oNext()}while(o!==s);return null}},interfaces_:function(){return[]},getClass:function(){return Fs}}),Fs.getTriangleEdges=function(t,e){if(e[0]=t,e[1]=e[0].lNext(),e[2]=e[1].lNext(),e[2].lNext()!==e[0])throw new i(\"Edges do not form a triangle\")},e(Gs.prototype,{visit:function(t){for(var e=t[0].orig().getCoordinate(),n=t[1].orig().getCoordinate(),i=t[2].orig().getCoordinate(),r=Si.circumcentre(e,n,i),s=new Ts(r),o=0;o<3;o++)t[o].rot().setOrig(s)},interfaces_:function(){return[As]},getClass:function(){return Gs}}),e(qs.prototype,{getTriangleEdges:function(){return this.triList},visit:function(t){this.triList.add(t.clone())},interfaces_:function(){return[As]},getClass:function(){return qs}}),e(Bs.prototype,{visit:function(t){this.triList.add([t[0].orig(),t[1].orig(),t[2].orig()])},getTriangleVertices:function(){return this.triList},interfaces_:function(){return[As]},getClass:function(){return Bs}}),e(zs.prototype,{checkTriangleSize:function(t){var e=\"\";t.length>=2?e=se.toLineString(t[0],t[1]):t.length>=1&&(e=se.toPoint(t[0]))},visit:function(t){this.coordList.clear();for(var e=0;e<3;e++){var n=t[e].orig();this.coordList.add(n.getCoordinate())}if(this.coordList.size()>0){this.coordList.closeRing();var i=this.coordList.toCoordinateArray();if(4!==i.length)return null;this.triCoords.add(i)}},getTriangles:function(){return this.triCoords},interfaces_:function(){return[As]},getClass:function(){return zs}}),Fs.TriangleCircumcentreVisitor=Gs,Fs.TriangleEdgesListVisitor=qs,Fs.TriangleVertexListVisitor=Bs,Fs.TriangleCoordinatesVisitor=zs,Fs.EDGE_COINCIDENCE_TOL_FACTOR=1e3,e(Vs.prototype,{getLineSegment:function(){return this.ls},getEndZ:function(){var t=this.ls.getCoordinate(1);return t.z},getStartZ:function(){var t=this.ls.getCoordinate(0);return t.z},intersection:function(t){return this.ls.intersection(t.getLineSegment())},getStart:function(){return this.ls.getCoordinate(0)},getEnd:function(){return this.ls.getCoordinate(1)},getEndY:function(){var t=this.ls.getCoordinate(1);return t.y},getStartX:function(){var t=this.ls.getCoordinate(0);return t.x},equalsTopo:function(t){return this.ls.equalsTopo(t.getLineSegment())},getStartY:function(){var t=this.ls.getCoordinate(0);return t.y},setData:function(t){this.data=t},getData:function(){return this.data},getEndX:function(){var t=this.ls.getCoordinate(1);return t.x},toString:function(){return this.ls.toString()},interfaces_:function(){return[]},getClass:function(){return Vs}}),e(ks.prototype,{visit:function(t){},interfaces_:function(){return[]},getClass:function(){return ks}}),e(Ys.prototype,{isRepeated:function(){return this.count>1},getRight:function(){return this.right},getCoordinate:function(){return this.p},setLeft:function(t){this.left=t},getX:function(){return this.p.x},getData:function(){return this.data},getCount:function(){return this.count},getLeft:function(){return this.left},getY:function(){return this.p.y},increment:function(){this.count=this.count+1},setRight:function(t){this.right=t},interfaces_:function(){return[]},getClass:function(){return Ys}}),e(Us.prototype,{insert:function(){if(1===arguments.length){var t=arguments[0];return this.insert(t,null)}if(2===arguments.length){var e=arguments[0],n=arguments[1];if(null===this.root)return this.root=new Ys(e,n),this.root;if(this.tolerance>0){var i=this.findBestMatchNode(e);if(null!==i)return i.increment(),i}return this.insertExact(e,n)}},query:function(){var t=arguments,e=this;if(1===arguments.length){var n=arguments[0],i=new I;return this.query(n,i),i}if(2===arguments.length)if(arguments[0]instanceof C&&R(arguments[1],y))!function(){var n=t[0],i=t[1];e.queryNode(e.root,n,!0,{interfaces_:function(){return[ks]},visit:function(t){i.add(t)}})}();else if(arguments[0]instanceof C&&R(arguments[1],ks)){var r=arguments[0],s=arguments[1];this.queryNode(this.root,r,!0,s)}},queryNode:function(t,e,n,i){if(null===t)return null;var r=null,s=null,o=null;n?(r=e.getMinX(),s=e.getMaxX(),o=t.getX()):(r=e.getMinY(),s=e.getMaxY(),o=t.getY());var a=r0&&te)&&xr.isWithinDistance(this,t,e)},distance:function(t){return xr.distance(this,t)},isEquivalentClass:function(t){return this.getClass()===t.getClass()}});var Go=\"1.3.0 (6e65adb)\";t.version=Go,t.algorithm=co,t.densify=fo,t.dissolve=go,t.geom=lo,t.geomgraph=po,t.index=yo,t.io=No,t.noding=Co,t.operation=_o,t.precision=Mo,t.simplify=Do,t.triangulate=Fo,Object.defineProperty(t,\"__esModule\",{value:!0})});\n","var getCoord = require('@turf/invariant').getCoord;\nvar radiansToDistance = require('@turf/helpers').radiansToDistance;\n//http://en.wikipedia.org/wiki/Haversine_formula\n//http://www.movable-type.co.uk/scripts/latlong.html\n\n/**\n * Calculates the distance between two {@link Point|points} in degrees, radians,\n * miles, or kilometers. This uses the\n * [Haversine formula](http://en.wikipedia.org/wiki/Haversine_formula)\n * to account for global curvature.\n *\n * @name distance\n * @param {Geometry|Feature|Array} from origin point\n * @param {Geometry|Feature|Array} to destination point\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {number} distance between the two points\n * @example\n * var from = turf.point([-75.343, 39.984]);\n * var to = turf.point([-75.534, 39.123]);\n *\n * var distance = turf.distance(from, to, \"miles\");\n *\n * //addToMap\n * var addToMap = [from, to];\n * from.properties.distance = distance;\n * to.properties.distance = distance;\n */\nmodule.exports = function (from, to, units) {\n var degrees2radians = Math.PI / 180;\n var coordinates1 = getCoord(from);\n var coordinates2 = getCoord(to);\n var dLat = degrees2radians * (coordinates2[1] - coordinates1[1]);\n var dLon = degrees2radians * (coordinates2[0] - coordinates1[0]);\n var lat1 = degrees2radians * coordinates1[1];\n var lat2 = degrees2radians * coordinates2[1];\n\n var a = Math.pow(Math.sin(dLat / 2), 2) +\n Math.pow(Math.sin(dLon / 2), 2) * Math.cos(lat1) * Math.cos(lat2);\n\n return radiansToDistance(2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)), units);\n};\n","'use strict'\n\nmodule.exports = convexHull2D\n\nvar monotoneHull = require('monotone-convex-hull-2d')\n\nfunction convexHull2D(points) {\n var hull = monotoneHull(points)\n var h = hull.length\n if(h <= 2) {\n return []\n }\n var edges = new Array(h)\n var a = hull[h-1]\n for(var i=0; i|Array} targetPoint the reference point\n * @param {FeatureCollection} points against input point set\n * @returns {Feature} the closest point in the set to the reference point\n * @example\n * var targetPoint = turf.point([28.965797, 41.010086], {\"marker-color\": \"#0F0\"});\n * var points = turf.featureCollection([\n * turf.point([28.973865, 41.011122]),\n * turf.point([28.948459, 41.024204]),\n * turf.point([28.938674, 41.013324])\n * ]);\n *\n * var nearest = turf.nearest(targetPoint, points);\n *\n * //addToMap\n * var addToMap = [targetPoint, points, nearest];\n * nearest.properties['marker-color'] = '#F00';\n */\nmodule.exports = function (targetPoint, points) {\n var nearestPoint, minDist = Infinity;\n for (var i = 0; i < points.features.length; i++) {\n var distanceToPoint = distance(targetPoint, points.features[i], 'miles');\n if (distanceToPoint < minDist) {\n nearestPoint = points.features[i];\n minDist = distanceToPoint;\n }\n }\n return nearestPoint;\n};\n","\"use strict\"\n\nvar twoProduct = require(\"two-product\")\nvar robustSum = require(\"robust-sum\")\nvar robustScale = require(\"robust-scale\")\nvar robustSubtract = require(\"robust-subtract\")\n\nvar NUM_EXPAND = 5\n\nvar EPSILON = 1.1102230246251565e-16\nvar ERRBOUND3 = (3.0 + 16.0 * EPSILON) * EPSILON\nvar ERRBOUND4 = (7.0 + 56.0 * EPSILON) * EPSILON\n\nfunction cofactor(m, c) {\n var result = new Array(m.length-1)\n for(var i=1; i>1\n return [\"sum(\", generateSum(expr.slice(0, m)), \",\", generateSum(expr.slice(m)), \")\"].join(\"\")\n }\n}\n\nfunction determinant(m) {\n if(m.length === 2) {\n return [[\"sum(prod(\", m[0][0], \",\", m[1][1], \"),prod(-\", m[0][1], \",\", m[1][0], \"))\"].join(\"\")]\n } else {\n var expr = []\n for(var i=0; i 0) {\n if(r <= 0) {\n return det\n } else {\n s = l + r\n }\n } else if(l < 0) {\n if(r >= 0) {\n return det\n } else {\n s = -(l + r)\n }\n } else {\n return det\n }\n var tol = ERRBOUND3 * s\n if(det >= tol || det <= -tol) {\n return det\n }\n return orientation3Exact(a, b, c)\n },\n function orientation4(a,b,c,d) {\n var adx = a[0] - d[0]\n var bdx = b[0] - d[0]\n var cdx = c[0] - d[0]\n var ady = a[1] - d[1]\n var bdy = b[1] - d[1]\n var cdy = c[1] - d[1]\n var adz = a[2] - d[2]\n var bdz = b[2] - d[2]\n var cdz = c[2] - d[2]\n var bdxcdy = bdx * cdy\n var cdxbdy = cdx * bdy\n var cdxady = cdx * ady\n var adxcdy = adx * cdy\n var adxbdy = adx * bdy\n var bdxady = bdx * ady\n var det = adz * (bdxcdy - cdxbdy) \n + bdz * (cdxady - adxcdy)\n + cdz * (adxbdy - bdxady)\n var permanent = (Math.abs(bdxcdy) + Math.abs(cdxbdy)) * Math.abs(adz)\n + (Math.abs(cdxady) + Math.abs(adxcdy)) * Math.abs(bdz)\n + (Math.abs(adxbdy) + Math.abs(bdxady)) * Math.abs(cdz)\n var tol = ERRBOUND4 * permanent\n if ((det > tol) || (-det > tol)) {\n return det\n }\n return orientation4Exact(a,b,c,d)\n }\n]\n\nfunction slowOrient(args) {\n var proc = CACHED[args.length]\n if(!proc) {\n proc = CACHED[args.length] = orientation(args.length)\n }\n return proc.apply(undefined, args)\n}\n\nfunction generateOrientationProc() {\n while(CACHED.length <= NUM_EXPAND) {\n CACHED.push(orientation(CACHED.length))\n }\n var args = []\n var procArgs = [\"slow\"]\n for(var i=0; i<=NUM_EXPAND; ++i) {\n args.push(\"a\" + i)\n procArgs.push(\"o\" + i)\n }\n var code = [\n \"function getOrientation(\", args.join(), \"){switch(arguments.length){case 0:case 1:return 0;\"\n ]\n for(var i=2; i<=NUM_EXPAND; ++i) {\n code.push(\"case \", i, \":return o\", i, \"(\", args.slice(0, i).join(), \");\")\n }\n code.push(\"}var s=new Array(arguments.length);for(var i=0;i\r\n \r\n \r\n \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!./SimpleTableSortingButton.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!./SimpleTableSortingButton.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SimpleTableSortingButton.vue?vue&type=template&id=6c9a549e&scoped=true&lang=html&\"\nimport script from \"./SimpleTableSortingButton.vue?vue&type=script&lang=js&\"\nexport * from \"./SimpleTableSortingButton.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SimpleTableSortingButton.vue?vue&type=style&index=0&id=6c9a549e&lang=scss&scoped=true&\"\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 \"6c9a549e\",\n null\n \n)\n\nexport default component.exports","\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!./SimpleTable.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!./SimpleTable.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SimpleTable.vue?vue&type=template&id=2728a880&scoped=true&lang=html&\"\nimport script from \"./SimpleTable.vue?vue&type=script&lang=js&\"\nexport * from \"./SimpleTable.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SimpleTable.vue?vue&type=style&index=0&id=2728a880&lang=scss&scoped=true&\"\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 \"2728a880\",\n null\n \n)\n\nexport default component.exports","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Vector handling functions (c) Chris Veness 2011-2016 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-vector3d.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\n\n\n/**\n * Library of 3-d vector manipulation routines.\n *\n * In a geodesy context, these vectors may be used to represent:\n * - n-vector representing a normal to point on Earth's surface\n * - earth-centered, earth fixed vector (≡ Gade’s ‘p-vector’)\n * - great circle normal to vector (on spherical earth model)\n * - motion vector on Earth's surface\n * - etc\n *\n * Functions return vectors as return results, so that operations can be chained.\n * @example var v = v1.cross(v2).dot(v3) // ≡ v1×v2⋅v3\n *\n * @module vector3d\n */\n\n\n/**\n * Creates a 3-d vector.\n *\n * The vector may be normalised, or use x/y/z values for eg height relative to the sphere or\n * ellipsoid, distance from earth centre, etc.\n *\n * @constructor\n * @param {number} x - X component of vector.\n * @param {number} y - Y component of vector.\n * @param {number} z - Z component of vector.\n */\nfunction Vector3d(x, y, z) {\n // allow instantiation without 'new'\n if (!(this instanceof Vector3d)) return new Vector3d(x, y, z);\n\n this.x = Number(x);\n this.y = Number(y);\n this.z = Number(z);\n}\n\n\n/**\n * Adds supplied vector to ‘this’ vector.\n *\n * @param {Vector3d} v - Vector to be added to this vector.\n * @returns {Vector3d} Vector representing sum of this and v.\n */\nVector3d.prototype.plus = function(v) {\n if (!(v instanceof Vector3d)) throw new TypeError('v is not Vector3d object');\n\n return new Vector3d(this.x + v.x, this.y + v.y, this.z + v.z);\n};\n\n\n/**\n * Subtracts supplied vector from ‘this’ vector.\n *\n * @param {Vector3d} v - Vector to be subtracted from this vector.\n * @returns {Vector3d} Vector representing difference between this and v.\n */\nVector3d.prototype.minus = function(v) {\n if (!(v instanceof Vector3d)) throw new TypeError('v is not Vector3d object');\n\n return new Vector3d(this.x - v.x, this.y - v.y, this.z - v.z);\n};\n\n\n/**\n * Multiplies ‘this’ vector by a scalar value.\n *\n * @param {number} x - Factor to multiply this vector by.\n * @returns {Vector3d} Vector scaled by x.\n */\nVector3d.prototype.times = function(x) {\n x = Number(x);\n\n return new Vector3d(this.x * x, this.y * x, this.z * x);\n};\n\n\n/**\n * Divides ‘this’ vector by a scalar value.\n *\n * @param {number} x - Factor to divide this vector by.\n * @returns {Vector3d} Vector divided by x.\n */\nVector3d.prototype.dividedBy = function(x) {\n x = Number(x);\n\n return new Vector3d(this.x / x, this.y / x, this.z / x);\n};\n\n\n/**\n * Multiplies ‘this’ vector by the supplied vector using dot (scalar) product.\n *\n * @param {Vector3d} v - Vector to be dotted with this vector.\n * @returns {number} Dot product of ‘this’ and v.\n */\nVector3d.prototype.dot = function(v) {\n if (!(v instanceof Vector3d)) throw new TypeError('v is not Vector3d object');\n\n return this.x*v.x + this.y*v.y + this.z*v.z;\n};\n\n\n/**\n * Multiplies ‘this’ vector by the supplied vector using cross (vector) product.\n *\n * @param {Vector3d} v - Vector to be crossed with this vector.\n * @returns {Vector3d} Cross product of ‘this’ and v.\n */\nVector3d.prototype.cross = function(v) {\n if (!(v instanceof Vector3d)) throw new TypeError('v is not Vector3d object');\n\n var x = this.y*v.z - this.z*v.y;\n var y = this.z*v.x - this.x*v.z;\n var z = this.x*v.y - this.y*v.x;\n\n return new Vector3d(x, y, z);\n};\n\n\n/**\n * Negates a vector to point in the opposite direction\n *\n * @returns {Vector3d} Negated vector.\n */\nVector3d.prototype.negate = function() {\n return new Vector3d(-this.x, -this.y, -this.z);\n};\n\n\n/**\n * Length (magnitude or norm) of ‘this’ vector\n *\n * @returns {number} Magnitude of this vector.\n */\nVector3d.prototype.length = function() {\n return Math.sqrt(this.x*this.x + this.y*this.y + this.z*this.z);\n};\n\n\n/**\n * Normalizes a vector to its unit vector\n * – if the vector is already unit or is zero magnitude, this is a no-op.\n *\n * @returns {Vector3d} Normalised version of this vector.\n */\nVector3d.prototype.unit = function() {\n var norm = this.length();\n if (norm == 1) return this;\n if (norm == 0) return this;\n\n var x = this.x/norm;\n var y = this.y/norm;\n var z = this.z/norm;\n\n return new Vector3d(x, y, z);\n};\n\n\n/**\n * Calculates the angle between ‘this’ vector and supplied vector δ = atan2(|p₁×p₂|, p₁·p₂).\n *\n * @param {Vector3d} v\n * @param {Vector3d} [n] - Plane normal: if supplied, angle is -π..+π, signed +ve if this->v is\n * clockwise looking along n, -ve in opposite direction (if not supplied, angle is always 0..π).\n * @returns {number} Angle (in radians) between this vector and supplied vector.\n */\nVector3d.prototype.angleTo = function(v, n) {\n if (!(v instanceof Vector3d)) throw new TypeError('v is not Vector3d object');\n if (!(n instanceof Vector3d || n == undefined)) throw new TypeError('n is not Vector3d object');\n\n var sign = n==undefined ? 1 : Math.sign(this.cross(v).dot(n));\n var sinθ = this.cross(v).length() * sign;\n var cosθ = this.dot(v);\n\n return Math.atan2(sinθ, cosθ);\n};\n\n\n/**\n * Rotates ‘this’ point around an axis by a specified angle.\n *\n * @param {Vector3d} axis - The axis being rotated around.\n * @param {number} theta - The angle of rotation (in radians).\n * @returns {Vector3d} The rotated point.\n */\nVector3d.prototype.rotateAround = function(axis, theta) {\n if (!(axis instanceof Vector3d)) throw new TypeError('axis is not Vector3d object');\n\n // en.wikipedia.org/wiki/Rotation_matrix#Rotation_matrix_from_axis_and_angle\n // en.wikipedia.org/wiki/Quaternions_and_spatial_rotation#Quaternion-derived_rotation_matrix\n var p1 = this.unit();\n var p = [ p1.x, p1.y, p1.z ]; // the point being rotated\n var a = axis.unit(); // the axis being rotated around\n var s = Math.sin(theta);\n var c = Math.cos(theta);\n // quaternion-derived rotation matrix\n var q = [\n [ a.x*a.x*(1-c) + c, a.x*a.y*(1-c) - a.z*s, a.x*a.z*(1-c) + a.y*s ],\n [ a.y*a.x*(1-c) + a.z*s, a.y*a.y*(1-c) + c, a.y*a.z*(1-c) - a.x*s ],\n [ a.z*a.x*(1-c) - a.y*s, a.z*a.y*(1-c) + a.x*s, a.z*a.z*(1-c) + c ],\n ];\n // multiply q × p\n var qp = [ 0, 0, 0 ];\n for (var i=0; i<3; i++) {\n for (var j=0; j<3; j++) {\n qp[i] += q[i][j] * p[j];\n }\n }\n var p2 = new Vector3d(qp[0], qp[1], qp[2]);\n return p2;\n // qv en.wikipedia.org/wiki/Rodrigues'_rotation_formula...\n};\n\n\n/**\n * String representation of vector.\n *\n * @param {number} [precision=3] - Number of decimal places to be used.\n * @returns {string} Vector represented as [x,y,z].\n */\nVector3d.prototype.toString = function(precision) {\n var p = (precision === undefined) ? 3 : Number(precision);\n\n var str = '[' + this.x.toFixed(p) + ',' + this.y.toFixed(p) + ',' + this.z.toFixed(p) + ']';\n\n return str;\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n/** Polyfill Math.sign for old browsers / IE */\nif (Math.sign === undefined) {\n Math.sign = function(x) {\n x = +x; // convert to a number\n if (x === 0 || isNaN(x)) return x;\n return x > 0 ? 1 : -1;\n };\n}\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = Vector3d; // ≡ export default Vector3d\n","/**\n * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}.\n *\n * @name feature\n * @param {Geometry} geometry input geometry\n * @param {Object} properties properties\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var geometry = {\n * \"type\": \"Point\",\n * \"coordinates\": [\n * 67.5,\n * 32.84267363195431\n * ]\n * }\n *\n * var feature = turf.feature(geometry);\n *\n * //=feature\n */\nfunction feature(geometry, properties) {\n if (!geometry) throw new Error('No geometry passed');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: geometry\n };\n}\nmodule.exports.feature = feature;\n\n/**\n * Takes coordinates and properties (optional) and returns a new {@link Point} feature.\n *\n * @name point\n * @param {Array} coordinates longitude, latitude position (each in decimal degrees)\n * @param {Object=} properties an Object that is used as the {@link Feature}'s\n * properties\n * @returns {Feature} a Point feature\n * @example\n * var pt1 = turf.point([-75.343, 39.984]);\n *\n * //=pt1\n */\nmodule.exports.point = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length === undefined) throw new Error('Coordinates must be an array');\n if (coordinates.length < 2) throw new Error('Coordinates must be at least 2 numbers long');\n if (typeof coordinates[0] !== 'number' || typeof coordinates[1] !== 'number') throw new Error('Coordinates must numbers');\n\n return feature({\n type: 'Point',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Takes an array of LinearRings and optionally an {@link Object} with properties and returns a {@link Polygon} feature.\n *\n * @name polygon\n * @param {Array>>} coordinates an array of LinearRings\n * @param {Object=} properties a properties object\n * @returns {Feature} a Polygon feature\n * @throws {Error} throw an error if a LinearRing of the polygon has too few positions\n * or if a LinearRing of the Polygon does not have matching Positions at the\n * beginning & end.\n * @example\n * var polygon = turf.polygon([[\n * [-2.275543, 53.464547],\n * [-2.275543, 53.489271],\n * [-2.215118, 53.489271],\n * [-2.215118, 53.464547],\n * [-2.275543, 53.464547]\n * ]], { name: 'poly1', population: 400});\n *\n * //=polygon\n */\nmodule.exports.polygon = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n for (var i = 0; i < coordinates.length; i++) {\n var ring = coordinates[i];\n if (ring.length < 4) {\n throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.');\n }\n for (var j = 0; j < ring[ring.length - 1].length; j++) {\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error('First and last Position are not equivalent.');\n }\n }\n }\n\n return feature({\n type: 'Polygon',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link LineString} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name lineString\n * @param {Array>} coordinates an array of Positions\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a LineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var linestring1 = turf.lineString([\n * [-21.964416, 64.148203],\n * [-21.956176, 64.141316],\n * [-21.93901, 64.135924],\n * [-21.927337, 64.136673]\n * ]);\n * var linestring2 = turf.lineString([\n * [-21.929054, 64.127985],\n * [-21.912918, 64.134726],\n * [-21.916007, 64.141016],\n * [-21.930084, 64.14446]\n * ], {name: 'line 1', distance: 145});\n *\n * //=linestring1\n *\n * //=linestring2\n */\nmodule.exports.lineString = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'LineString',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}.\n *\n * @name featureCollection\n * @param {Feature[]} features input features\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var features = [\n * turf.point([-75.343, 39.984], {name: 'Location A'}),\n * turf.point([-75.833, 39.284], {name: 'Location B'}),\n * turf.point([-75.534, 39.123], {name: 'Location C'})\n * ];\n *\n * var fc = turf.featureCollection(features);\n *\n * //=fc\n */\nmodule.exports.featureCollection = function (features) {\n if (!features) throw new Error('No features passed');\n\n return {\n type: 'FeatureCollection',\n features: features\n };\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiLineString\n * @param {Array>>} coordinates an array of LineStrings\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a MultiLineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiLine = turf.multiLineString([[[0,0],[10,10]]]);\n *\n * //=multiLine\n *\n */\nmodule.exports.multiLineString = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiLineString',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPoint\n * @param {Array>} coordinates an array of Positions\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a MultiPoint feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPt = turf.multiPoint([[0,0],[10,10]]);\n *\n * //=multiPt\n *\n */\nmodule.exports.multiPoint = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPoint',\n coordinates: coordinates\n }, properties);\n};\n\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPolygon\n * @param {Array>>>} coordinates an array of Polygons\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a multipolygon feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]);\n *\n * //=multiPoly\n *\n */\nmodule.exports.multiPolygon = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPolygon',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name geometryCollection\n * @param {Array<{Geometry}>} geometries an array of GeoJSON Geometries\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a GeoJSON GeometryCollection Feature\n * @example\n * var pt = {\n * \"type\": \"Point\",\n * \"coordinates\": [100, 0]\n * };\n * var line = {\n * \"type\": \"LineString\",\n * \"coordinates\": [ [101, 0], [102, 1] ]\n * };\n * var collection = turf.geometryCollection([pt, line]);\n *\n * //=collection\n */\nmodule.exports.geometryCollection = function (geometries, properties) {\n if (!geometries) throw new Error('No geometries passed');\n\n return feature({\n type: 'GeometryCollection',\n geometries: geometries\n }, properties);\n};\n\nvar factors = {\n miles: 3960,\n nauticalmiles: 3441.145,\n degrees: 57.2957795,\n radians: 1,\n inches: 250905600,\n yards: 6969600,\n meters: 6373000,\n metres: 6373000,\n kilometers: 6373,\n kilometres: 6373,\n feet: 20908792.65\n};\n\n/*\n * Convert a distance measurement from radians to a more friendly unit.\n *\n * @name radiansToDistance\n * @param {number} distance in radians across the sphere\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} distance\n */\nmodule.exports.radiansToDistance = function (radians, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return radians * factor;\n};\n\n/*\n * Convert a distance measurement from a real-world unit into radians\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} radians\n */\nmodule.exports.distanceToRadians = function (distance, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return distance / factor;\n};\n\n/*\n * Convert a distance measurement from a real-world unit into degrees\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} degrees\n */\nmodule.exports.distanceToDegrees = function (distance, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return (distance / factor) * 57.2958;\n};\n","var getCoords = require('@turf/invariant').getCoords;\n\n/**\n * Returns true if a point is on a line. Accepts a optional parameter to ignore the start and end vertices of the linestring.\n *\n * @name booleanPointOnLine\n * @param {Geometry|Feature} point GeoJSON Feature or Geometry\n * @param {Geometry|Feature} linestring GeoJSON Feature or Geometry\n * @param {boolean} [ignoreEndVertices=false] whether to ignore the start and end vertices.\n * @returns {boolean} true/false\n * @example\n * var pt = turf.point([0, 0]);\n * var line = turf.lineString([[-1, -1],[1, 1],[1.5, 2.2]]);\n * var isPointOnLine = turf.booleanPointOnLine(pt, line);\n * //=true\n */\nmodule.exports = function (point, linestring, ignoreEndVertices) {\n var pointCoords = getCoords(point);\n var lineCoords = getCoords(linestring);\n for (var i = 0; i < lineCoords.length - 1; i++) {\n var ignoreBoundary = false;\n if (ignoreEndVertices) {\n if (i === 0) ignoreBoundary = 'start';\n if (i === lineCoords.length - 2) ignoreBoundary = 'end';\n if (i === 0 && i + 1 === lineCoords.length - 1) ignoreBoundary = 'both';\n }\n if (isPointOnLineSegment(lineCoords[i], lineCoords[i + 1], pointCoords, ignoreBoundary)) return true;\n }\n return false;\n};\n\n// See http://stackoverflow.com/a/4833823/1979085\n/**\n * @private\n * @param {Array} lineSegmentStart coord pair of start of line\n * @param {Array} lineSegmentEnd coord pair of end of line\n * @param {Array} point coord pair of point to check\n * @param {boolean|string} excludeBoundary whether the point is allowed to fall on the line ends. If true which end to ignore.\n * @returns {boolean} true/false\n */\nfunction isPointOnLineSegment(lineSegmentStart, lineSegmentEnd, point, excludeBoundary) {\n var dxc = point[0] - lineSegmentStart[0];\n var dyc = point[1] - lineSegmentStart[1];\n var dxl = lineSegmentEnd[0] - lineSegmentStart[0];\n var dyl = lineSegmentEnd[1] - lineSegmentStart[1];\n var cross = dxc * dyl - dyc * dxl;\n if (cross !== 0) {\n return false;\n }\n if (!excludeBoundary) {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] <= point[0] && point[0] <= lineSegmentEnd[0] : lineSegmentEnd[0] <= point[0] && point[0] <= lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] <= point[1] && point[1] <= lineSegmentEnd[1] : lineSegmentEnd[1] <= point[1] && point[1] <= lineSegmentStart[1];\n } else if (excludeBoundary === 'start') {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] < point[0] && point[0] <= lineSegmentEnd[0] : lineSegmentEnd[0] <= point[0] && point[0] < lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] < point[1] && point[1] <= lineSegmentEnd[1] : lineSegmentEnd[1] <= point[1] && point[1] < lineSegmentStart[1];\n } else if (excludeBoundary === 'end') {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] <= point[0] && point[0] < lineSegmentEnd[0] : lineSegmentEnd[0] < point[0] && point[0] <= lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] <= point[1] && point[1] < lineSegmentEnd[1] : lineSegmentEnd[1] < point[1] && point[1] <= lineSegmentStart[1];\n } else if (excludeBoundary === 'both') {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] < point[0] && point[0] < lineSegmentEnd[0] : lineSegmentEnd[0] < point[0] && point[0] < lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] < point[1] && point[1] < lineSegmentEnd[1] : lineSegmentEnd[1] < point[1] && point[1] < lineSegmentStart[1];\n }\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n *\n * Expose `debug()` as the module.\n */\n\nexports = module.exports = createDebug.debug = createDebug['default'] = createDebug;\nexports.coerce = coerce;\nexports.disable = disable;\nexports.enable = enable;\nexports.enabled = enabled;\nexports.humanize = require('ms');\n\n/**\n * The currently active debug mode names, and names to skip.\n */\n\nexports.names = [];\nexports.skips = [];\n\n/**\n * Map of special \"%n\" handling functions, for the debug \"format\" argument.\n *\n * Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n */\n\nexports.formatters = {};\n\n/**\n * Previous log timestamp.\n */\n\nvar prevTime;\n\n/**\n * Select a color.\n * @param {String} namespace\n * @return {Number}\n * @api private\n */\n\nfunction selectColor(namespace) {\n var hash = 0, i;\n\n for (i in namespace) {\n hash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n hash |= 0; // Convert to 32bit integer\n }\n\n return exports.colors[Math.abs(hash) % exports.colors.length];\n}\n\n/**\n * Create a debugger with the given `namespace`.\n *\n * @param {String} namespace\n * @return {Function}\n * @api public\n */\n\nfunction createDebug(namespace) {\n\n function debug() {\n // disabled?\n if (!debug.enabled) return;\n\n var self = debug;\n\n // set `diff` timestamp\n var curr = +new Date();\n var ms = curr - (prevTime || curr);\n self.diff = ms;\n self.prev = prevTime;\n self.curr = curr;\n prevTime = curr;\n\n // turn the `arguments` into a proper Array\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n\n args[0] = exports.coerce(args[0]);\n\n if ('string' !== typeof args[0]) {\n // anything else let's inspect with %O\n args.unshift('%O');\n }\n\n // apply any `formatters` transformations\n var index = 0;\n args[0] = args[0].replace(/%([a-zA-Z%])/g, function(match, format) {\n // if we encounter an escaped % then don't increase the array index\n if (match === '%%') return match;\n index++;\n var formatter = exports.formatters[format];\n if ('function' === typeof formatter) {\n var val = args[index];\n match = formatter.call(self, val);\n\n // now we need to remove `args[index]` since it's inlined in the `format`\n args.splice(index, 1);\n index--;\n }\n return match;\n });\n\n // apply env-specific formatting (colors, etc.)\n exports.formatArgs.call(self, args);\n\n var logFn = debug.log || exports.log || console.log.bind(console);\n logFn.apply(self, args);\n }\n\n debug.namespace = namespace;\n debug.enabled = exports.enabled(namespace);\n debug.useColors = exports.useColors();\n debug.color = selectColor(namespace);\n\n // env-specific initialization logic for debug instances\n if ('function' === typeof exports.init) {\n exports.init(debug);\n }\n\n return debug;\n}\n\n/**\n * Enables a debug mode by namespaces. This can include modes\n * separated by a colon and wildcards.\n *\n * @param {String} namespaces\n * @api public\n */\n\nfunction enable(namespaces) {\n exports.save(namespaces);\n\n exports.names = [];\n exports.skips = [];\n\n var split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n var len = split.length;\n\n for (var i = 0; i < len; i++) {\n if (!split[i]) continue; // ignore empty strings\n namespaces = split[i].replace(/\\*/g, '.*?');\n if (namespaces[0] === '-') {\n exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n } else {\n exports.names.push(new RegExp('^' + namespaces + '$'));\n }\n }\n}\n\n/**\n * Disable debug output.\n *\n * @api public\n */\n\nfunction disable() {\n exports.enable('');\n}\n\n/**\n * Returns true if the given mode name is enabled, false otherwise.\n *\n * @param {String} name\n * @return {Boolean}\n * @api public\n */\n\nfunction enabled(name) {\n var i, len;\n for (i = 0, len = exports.skips.length; i < len; i++) {\n if (exports.skips[i].test(name)) {\n return false;\n }\n }\n for (i = 0, len = exports.names.length; i < len; i++) {\n if (exports.names[i].test(name)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * Coerce `val`.\n *\n * @param {Mixed} val\n * @return {Mixed}\n * @api private\n */\n\nfunction coerce(val) {\n if (val instanceof Error) return val.stack || val.message;\n return val;\n}\n","/* eslint-disable */\n\n /**\n * BezierSpline\n * https://github.com/leszekr/bezier-spline-js\n *\n * @private\n * @copyright\n * Copyright (c) 2013 Leszek Rybicki\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nvar Spline = function (options) {\n this.points = options.points || [];\n this.duration = options.duration || 10000;\n this.sharpness = options.sharpness || 0.85;\n this.centers = [];\n this.controls = [];\n this.stepLength = options.stepLength || 60;\n this.length = this.points.length;\n this.delay = 0;\n // this is to ensure compatibility with the 2d version\n for (var i = 0; i < this.length; i++) this.points[i].z = this.points[i].z || 0;\n for (var i = 0; i < this.length - 1; i++) {\n var p1 = this.points[i];\n var p2 = this.points[i + 1];\n this.centers.push({\n x: (p1.x + p2.x) / 2,\n y: (p1.y + p2.y) / 2,\n z: (p1.z + p2.z) / 2\n });\n }\n this.controls.push([this.points[0], this.points[0]]);\n for (var i = 0; i < this.centers.length - 1; i++) {\n var p1 = this.centers[i];\n var p2 = this.centers[i + 1];\n var dx = this.points[i + 1].x - (this.centers[i].x + this.centers[i + 1].x) / 2;\n var dy = this.points[i + 1].y - (this.centers[i].y + this.centers[i + 1].y) / 2;\n var dz = this.points[i + 1].z - (this.centers[i].y + this.centers[i + 1].z) / 2;\n this.controls.push([{\n x: (1.0 - this.sharpness) * this.points[i + 1].x + this.sharpness * (this.centers[i].x + dx),\n y: (1.0 - this.sharpness) * this.points[i + 1].y + this.sharpness * (this.centers[i].y + dy),\n z: (1.0 - this.sharpness) * this.points[i + 1].z + this.sharpness * (this.centers[i].z + dz)},\n {\n x: (1.0 - this.sharpness) * this.points[i + 1].x + this.sharpness * (this.centers[i + 1].x + dx),\n y: (1.0 - this.sharpness) * this.points[i + 1].y + this.sharpness * (this.centers[i + 1].y + dy),\n z: (1.0 - this.sharpness) * this.points[i + 1].z + this.sharpness * (this.centers[i + 1].z + dz)}]);\n }\n this.controls.push([this.points[this.length - 1], this.points[this.length - 1]]);\n this.steps = this.cacheSteps(this.stepLength);\n return this;\n};\n\n /*\n Caches an array of equidistant (more or less) points on the curve.\n */\nSpline.prototype.cacheSteps = function (mindist) {\n var steps = [];\n var laststep = this.pos(0);\n steps.push(0);\n for (var t = 0; t < this.duration; t += 10) {\n var step = this.pos(t);\n var dist = Math.sqrt((step.x - laststep.x) * (step.x - laststep.x) + (step.y - laststep.y) * (step.y - laststep.y) + (step.z - laststep.z) * (step.z - laststep.z));\n if (dist > mindist) {\n steps.push(t);\n laststep = step;\n }\n }\n return steps;\n};\n\n /*\n returns angle and speed in the given point in the curve\n */\nSpline.prototype.vector = function (t) {\n var p1 = this.pos(t + 10);\n var p2 = this.pos(t - 10);\n return {\n angle:180 * Math.atan2(p1.y - p2.y, p1.x - p2.x) / 3.14,\n speed:Math.sqrt((p2.x - p1.x) * (p2.x - p1.x) + (p2.y - p1.y) * (p2.y - p1.y) + (p2.z - p1.z) * (p2.z - p1.z))\n };\n};\n\n /*\n Gets the position of the point, given time.\n\n WARNING: The speed is not constant. The time it takes between control points is constant.\n\n For constant speed, use Spline.steps[i];\n */\nSpline.prototype.pos = function (time) {\n\n function bezier(t, p1, c1, c2, p2) {\n var B = function (t) {\n var t2 = t * t, t3 = t2 * t;\n return [(t3), (3 * t2 * (1 - t)), (3 * t * (1 - t) * (1 - t)), ((1 - t) * (1 - t) * (1 - t))];\n };\n var b = B(t);\n var pos = {\n x : p2.x * b[0] + c2.x * b[1] + c1.x * b[2] + p1.x * b[3],\n y : p2.y * b[0] + c2.y * b[1] + c1.y * b[2] + p1.y * b[3],\n z : p2.z * b[0] + c2.z * b[1] + c1.z * b[2] + p1.z * b[3]\n };\n return pos;\n }\n var t = time - this.delay;\n if (t < 0) t = 0;\n if (t > this.duration) t = this.duration - 1;\n //t = t-this.delay;\n var t2 = (t) / this.duration;\n if (t2 >= 1) return this.points[this.length - 1];\n\n var n = Math.floor((this.points.length - 1) * t2);\n var t1 = (this.length - 1) * t2 - n;\n return bezier(t1, this.points[n], this.controls[n][1], this.controls[n + 1][0], this.points[n + 1]);\n};\n\nmodule.exports = Spline;\n","import mod from \"-!../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./InputClearButton.vue?vue&type=style&index=0&id=451fb25d&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./InputClearButton.vue?vue&type=style&index=0&id=451fb25d&lang=scss&scoped=true&\"","var area = require('@mapbox/geojson-area').geometry;\nvar geomReduce = require('@turf/meta').geomReduce;\n\n/**\n * Takes one or more features and returns their area in square meters.\n *\n * @name area\n * @param {FeatureCollection|Feature} geojson input GeoJSON feature(s)\n * @returns {number} area in square meters\n * @addToMap polygon\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [\n * [\n * [125, -15],\n * [113, -22],\n * [117, -37],\n * [130, -33],\n * [148, -39],\n * [154, -27],\n * [144, -15],\n * [125, -15]\n * ]\n * ]\n * }\n * }\n * var area = turf.area(polygon);\n * //=area => square meters\n * //=polygon\n */\nmodule.exports = function (geojson) {\n return geomReduce(geojson, function (value, geometry) {\n return value + area(geometry);\n }, 0);\n};\n","var simplifyJS = require('simplify-js');\nvar cleanCoords = require('@turf/clean-coords');\nvar geomEach = require('@turf/meta').geomEach;\nvar clone = require('@turf/clone');\n\n/**\n * Takes a {@link GeoJSON} object and returns a simplified version. Internally uses\n * [simplify-js](http://mourner.github.io/simplify-js/) to perform simplification.\n *\n * @name simplify\n * @param {GeoJSON} geojson object to be simplified\n * @param {number} [tolerance=1] simplification tolerance\n * @param {boolean} [highQuality=false] whether or not to spend more time to create a higher-quality simplification with a different algorithm\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} a simplified GeoJSON\n * @example\n * var geojson = turf.polygon([[\n * [-70.603637, -33.399918],\n * [-70.614624, -33.395332],\n * [-70.639343, -33.392466],\n * [-70.659942, -33.394759],\n * [-70.683975, -33.404504],\n * [-70.697021, -33.419406],\n * [-70.701141, -33.434306],\n * [-70.700454, -33.446339],\n * [-70.694274, -33.458369],\n * [-70.682601, -33.465816],\n * [-70.668869, -33.472117],\n * [-70.646209, -33.473835],\n * [-70.624923, -33.472117],\n * [-70.609817, -33.468107],\n * [-70.595397, -33.458369],\n * [-70.587158, -33.442901],\n * [-70.587158, -33.426283],\n * [-70.590591, -33.414248],\n * [-70.594711, -33.406224],\n * [-70.603637, -33.399918]\n * ]]);\n * var tolerance = 0.01;\n *\n * var simplified = turf.simplify(geojson, tolerance, false);\n *\n * //addToMap\n * var addToMap = [geojson, simplified]\n */\nmodule.exports = function (geojson, tolerance, highQuality, mutate) {\n if (!geojson) throw new Error('geojson is required');\n if (tolerance && tolerance < 0) throw new Error('invalid tolerance');\n\n // Clone geojson to avoid side effects\n if (mutate !== true) geojson = clone(geojson);\n\n geomEach(geojson, function (geom) {\n simplify(geom, tolerance, highQuality);\n });\n return geojson;\n};\n\n/**\n * Simplifies a feature's coordinates\n *\n * @private\n * @param {Geometry} geometry to be simplified\n * @param {number} [tolerance=1] simplification tolerance\n * @param {boolean} [highQuality=false] whether or not to spend more time to create a higher-quality simplification with a different algorithm\n * @returns {Geometry} output\n */\nfunction simplify(geometry, tolerance, highQuality) {\n var type = geometry.type;\n\n // \"unsimplyfiable\" geometry types\n if (type === 'Point' || type === 'MultiPoint') return geometry;\n\n // Remove any extra coordinates\n cleanCoords(geometry, true);\n\n var coordinates = geometry.coordinates;\n switch (type) {\n case 'LineString':\n geometry['coordinates'] = simplifyLine(coordinates, tolerance, highQuality);\n break;\n case 'MultiLineString':\n geometry['coordinates'] = coordinates.map(function (lines) {\n return simplifyLine(lines, tolerance, highQuality);\n });\n break;\n case 'Polygon':\n geometry['coordinates'] = simplifyPolygon(coordinates, tolerance, highQuality);\n break;\n case 'MultiPolygon':\n geometry['coordinates'] = coordinates.map(function (rings) {\n return simplifyPolygon(rings, tolerance, highQuality);\n });\n }\n return geometry;\n}\n\n\n/**\n * Simplifies the coordinates of a LineString with simplify-js\n *\n * @private\n * @param {Array} coordinates to be processed\n * @param {number} tolerance simplification tolerance\n * @param {boolean} highQuality whether or not to spend more time to create a higher-quality\n * @returns {Array>} simplified coords\n */\nfunction simplifyLine(coordinates, tolerance, highQuality) {\n return simplifyJS(coordinates.map(function (coord) {\n return {x: coord[0], y: coord[1], z: coord[2]};\n }), tolerance, highQuality).map(function (coords) {\n return (coords.z) ? [coords.x, coords.y, coords.z] : [coords.x, coords.y];\n });\n}\n\n\n/**\n * Simplifies the coordinates of a Polygon with simplify-js\n *\n * @private\n * @param {Array} coordinates to be processed\n * @param {number} tolerance simplification tolerance\n * @param {boolean} highQuality whether or not to spend more time to create a higher-quality\n * @returns {Array>>} simplified coords\n */\nfunction simplifyPolygon(coordinates, tolerance, highQuality) {\n return coordinates.map(function (ring) {\n var pts = ring.map(function (coord) {\n return {x: coord[0], y: coord[1]};\n });\n if (pts.length < 4) {\n throw new Error('invalid polygon');\n }\n var simpleRing = simplifyJS(pts, tolerance, highQuality).map(function (coords) {\n return [coords.x, coords.y];\n });\n //remove 1 percent of tolerance until enough points to make a triangle\n while (!checkValidity(simpleRing)) {\n tolerance -= tolerance * 0.01;\n simpleRing = simplifyJS(pts, tolerance, highQuality).map(function (coords) {\n return [coords.x, coords.y];\n });\n }\n if (\n (simpleRing[simpleRing.length - 1][0] !== simpleRing[0][0]) ||\n (simpleRing[simpleRing.length - 1][1] !== simpleRing[0][1])) {\n simpleRing.push(simpleRing[0]);\n }\n return simpleRing;\n });\n}\n\n\n/**\n * Returns true if ring has at least 3 coordinates and its first coordinate is the same as its last\n *\n * @private\n * @param {Array} ring coordinates to be checked\n * @returns {boolean} true if valid\n */\nfunction checkValidity(ring) {\n if (ring.length < 3) return false;\n //if the last point is the same as the first, it's not a triangle\n return !(ring.length === 3 && ((ring[2][0] === ring[0][0]) && (ring[2][1] === ring[0][1])));\n}\n","var supportsArgumentsClass = (function(){\n return Object.prototype.toString.call(arguments)\n})() == '[object Arguments]';\n\nexports = module.exports = supportsArgumentsClass ? supported : unsupported;\n\nexports.supported = supported;\nfunction supported(object) {\n return Object.prototype.toString.call(object) == '[object Arguments]';\n};\n\nexports.unsupported = unsupported;\nfunction unsupported(object){\n return object &&\n typeof object == 'object' &&\n typeof object.length == 'number' &&\n Object.prototype.hasOwnProperty.call(object, 'callee') &&\n !Object.prototype.propertyIsEnumerable.call(object, 'callee') ||\n false;\n};\n","// (logic of computation inspired by:\n// https://stackoverflow.com/questions/32771458/distance-from-lat-lng-point-to-minor-arc-segment)\n\nvar meta = require('@turf/meta');\nvar bearing = require('@turf/bearing');\nvar helpers = require('@turf/helpers');\nvar distance = require('@turf/distance');\nvar invariant = require('@turf/invariant');\nvar rhumbBearing = require('@turf/rhumb-bearing');\nvar rhumbDistance = require('@turf/rhumb-distance');\nvar turfLine = helpers.lineString;\nvar featureOf = invariant.featureOf;\nvar turfPoint = helpers.point;\nvar segmentEach = meta.segmentEach;\nvar bearingToAngle = helpers.bearingToAngle;\nvar convertDistance = helpers.convertDistance;\nvar degrees2radians = helpers.degrees2radians;\n\n/**\n * Returns the minimum distance between a {@link Point} and a {@link LineString}, being the distance from a line the\n * minimum distance between the point and any segment of the `LineString`.\n *\n * @name pointToLineDistance\n * @param {Feature|Array} point Feature or Geometry\n * @param {Feature|Array>} line GeoJSON Feature or Geometry\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @param {boolean} [mercator=false] if distance should be on Mercator or WGS84 projection\n * @returns {number} distance between point and line\n * @example\n * var pt = turf.point([0, 0]);\n * var line = turf.lineString([[1, 1],[-1, 1]]);\n *\n * var distance = turf.pointToLineDistance(pt, line, 'miles');\n * //=69.11854715938406\n */\nmodule.exports = function (point, line, units, mercator) {\n // validation\n if (!point) throw new Error('point is required');\n if (Array.isArray(point)) point = turfPoint(point);\n else featureOf(point, 'Point', 'point');\n if (!line) throw new Error('line is required');\n if (Array.isArray(line)) line = turfLine(line);\n else featureOf(line, 'LineString', 'line');\n\n var distance = Infinity;\n var p = point.geometry.coordinates;\n segmentEach(line, function (segment) {\n var a = segment.geometry.coordinates[0];\n var b = segment.geometry.coordinates[1];\n var d = distanceToSegment(p, a, b, units, mercator);\n if (distance > d) distance = d;\n });\n return distance;\n};\n\n\n/**\n * Returns the distance between a point P on a segment AB.\n *\n * @private\n * @param {Array} p external point\n * @param {Array} a first segment point\n * @param {Array} b second segment point\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @param {boolean} [mercator=false] if distance should be on Mercator or WGS84 projection\n * @returns {number} distance\n */\nfunction distanceToSegment(p, a, b, units, mercator) {\n\n var distanceAP = (mercator !== true) ? distance(a, p, units) : euclideanDistance(a, p, units);\n var azimuthAP = bearingToAngle((mercator !== true) ? bearing(a, p) : rhumbBearing(a, p));\n var azimuthAB = bearingToAngle((mercator !== true) ? bearing(a, b) : rhumbBearing(a, b));\n var angleA = Math.abs(azimuthAP - azimuthAB);\n // if (angleA > 180) angleA = Math.abs(angleA - 360);\n // if the angle PAB is obtuse its projection on the line extending the segment falls outside the segment\n // thus return distance between P and the start point A\n /*\n P__\n |\\ \\____\n | \\ \\____\n | \\ \\____\n | \\_____________\\\n H A B\n */\n if (angleA > 90) return distanceAP;\n\n var azimuthBA = (azimuthAB + 180) % 360;\n var azimuthBP = bearingToAngle((mercator !== true) ? bearing(b, p) : rhumbBearing(b, p));\n var angleB = Math.abs(azimuthBP - azimuthBA);\n if (angleB > 180) angleB = Math.abs(angleB - 360);\n // also if the angle ABP is acute the projection of P falls outside the segment, on the other side\n // so return the distance between P and the end point B\n /*\n ____P\n ____/ /|\n ____/ / |\n ____/ / |\n /______________/ |\n A B H\n */\n if (angleB > 90) return (mercator !== true) ? distance(p, b, units) : euclideanDistance(p, b, units);\n // finally if the projection falls inside the segment\n // return the distance between P and the segment\n /*\n P\n __/|\\\n __/ | \\\n __/ | \\\n __/ | \\\n /____________|____\\\n A H B\n */\n if (mercator !== true) return distanceAP * Math.sin(degrees2radians(angleA));\n return mercatorPH(a, b, p, units);\n}\n\n/**\n * Returns the distance between a point P on a segment AB, on Mercator projection\n *\n * @private\n * @param {Array} a first segment point\n * @param {Array} b second segment point\n * @param {Array} p external point\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {number} distance\n */\nfunction mercatorPH(a, b, p, units) {\n var delta = 0;\n // translate points if any is crossing the 180th meridian\n if (Math.abs(a[0]) >= 180 || Math.abs(b[0]) >= 180 || Math.abs(p[0]) >= 180) {\n delta = (a[0] > 0 || b[0] > 0 || p[0] > 0) ? -180 : 180;\n }\n\n var origin = turfPoint(p);\n var A = toMercator([a[0] + delta, a[1]]);\n var B = toMercator([b[0] + delta, b[1]]);\n var P = toMercator([p[0] + delta, p[1]]);\n var h = toWGS84(euclideanIntersection(A, B, P));\n\n if (delta !== 0) h[0] -= delta; // translate back to original position\n var distancePH = rhumbDistance(origin, h, units);\n return distancePH;\n}\n\n\n/**\n * Returns the point H projection of a point P on a segment AB, on the euclidean plain\n * from https://stackoverflow.com/questions/10301001/perpendicular-on-a-line-segment-from-a-given-point#answer-12499474\n * P\n * |\n * |\n * _________|____\n * A H B\n *\n * @private\n * @param {Array} a first segment point\n * @param {Array} b second segment point\n * @param {Array} p external point\n * @returns {Array} projected point\n */\nfunction euclideanIntersection(a, b, p) {\n var x1 = a[0], y1 = a[1],\n x2 = b[0], y2 = b[1],\n x3 = p[0], y3 = p[1];\n var px = x2 - x1, py = y2 - y1;\n var dab = px * px + py * py;\n var u = ((x3 - x1) * px + (y3 - y1) * py) / dab;\n var x = x1 + u * px, y = y1 + u * py;\n return [x, y]; // H\n}\n\n\n/**\n * Returns euclidean distance between two points\n *\n * @private\n * @param {Object} from first point\n * @param {Object} to second point\n * @param {string} units can be degrees, radians, miles, or kilometers\n * @returns {number} squared distance\n */\nfunction euclideanDistance(from, to, units) {\n // translate points if any is crossing the 180th meridian\n var delta = 0;\n if (Math.abs(from[0]) >= 180) {\n delta = (from[0] > 0) ? -180 : 180;\n }\n if (Math.abs(to[0]) >= 180) {\n delta = (to[0] > 0) ? -180 : 180;\n }\n var p1 = toMercator([from[0] + delta, from[1]]);\n var p2 = toMercator([to[0] + delta, to[1]]);\n\n var sqr = function (n) { return n * n; };\n var squareD = sqr(p1[0] - p2[0]) + sqr(p1[1] - p2[1]);\n var d = Math.sqrt(squareD);\n return convertDistance(d, 'meters', units);\n}\n\n/**\n * Convert lon/lat values to 900913 x/y.\n * from https://github.com/mapbox/sphericalmercator\n *\n * @private\n * @param {Array} lonLat WGS84 point\n * @returns {Array} Mercator [x, y] point\n */\nfunction toMercator(lonLat) {\n var D2R = Math.PI / 180,\n // 900913 properties.\n A = 6378137.0,\n MAXEXTENT = 20037508.342789244;\n\n var xy = [\n A * lonLat[0] * D2R,\n A * Math.log(Math.tan((Math.PI * 0.25) + (0.5 * lonLat[1] * D2R)))\n ];\n // if xy value is beyond maxextent (e.g. poles), return maxextent.\n if (xy[0] > MAXEXTENT) xy[0] = MAXEXTENT;\n if (xy[0] < -MAXEXTENT) xy[0] = -MAXEXTENT;\n if (xy[1] > MAXEXTENT) xy[1] = MAXEXTENT;\n if (xy[1] < -MAXEXTENT) xy[1] = -MAXEXTENT;\n return xy;\n}\n\n/**\n * Convert 900913 x/y values to lon/lat.\n * from https://github.com/mapbox/sphericalmercator\n *\n * @private\n * @param {Array} xy Mercator [x, y] point\n * @returns {Array} WGS84 [lon, lat] point\n */\nfunction toWGS84(xy) {\n // 900913 properties.\n var R2D = 180 / Math.PI,\n A = 6378137.0;\n\n return [\n (xy[0] * R2D / A),\n ((Math.PI * 0.5) - 2.0 * Math.atan(Math.exp(-xy[1] / A))) * R2D\n ];\n}\n","var wgs84 = require('wgs84');\n\nmodule.exports.geometry = geometry;\nmodule.exports.ring = ringArea;\n\nfunction geometry(_) {\n var area = 0, i;\n switch (_.type) {\n case 'Polygon':\n return polygonArea(_.coordinates);\n case 'MultiPolygon':\n for (i = 0; i < _.coordinates.length; i++) {\n area += polygonArea(_.coordinates[i]);\n }\n return area;\n case 'Point':\n case 'MultiPoint':\n case 'LineString':\n case 'MultiLineString':\n return 0;\n case 'GeometryCollection':\n for (i = 0; i < _.geometries.length; i++) {\n area += geometry(_.geometries[i]);\n }\n return area;\n }\n}\n\nfunction polygonArea(coords) {\n var area = 0;\n if (coords && coords.length > 0) {\n area += Math.abs(ringArea(coords[0]));\n for (var i = 1; i < coords.length; i++) {\n area -= Math.abs(ringArea(coords[i]));\n }\n }\n return area;\n}\n\n/**\n * Calculate the approximate area of the polygon were it projected onto\n * the earth. Note that this area will be positive if ring is oriented\n * clockwise, otherwise it will be negative.\n *\n * Reference:\n * Robert. G. Chamberlain and William H. Duquette, \"Some Algorithms for\n * Polygons on a Sphere\", JPL Publication 07-03, Jet Propulsion\n * Laboratory, Pasadena, CA, June 2007 http://trs-new.jpl.nasa.gov/dspace/handle/2014/40409\n *\n * Returns:\n * {float} The approximate signed geodesic area of the polygon in square\n * meters.\n */\n\nfunction ringArea(coords) {\n var p1, p2, p3, lowerIndex, middleIndex, upperIndex, i,\n area = 0,\n coordsLength = coords.length;\n\n if (coordsLength > 2) {\n for (i = 0; i < coordsLength; i++) {\n if (i === coordsLength - 2) {// i = N-2\n lowerIndex = coordsLength - 2;\n middleIndex = coordsLength -1;\n upperIndex = 0;\n } else if (i === coordsLength - 1) {// i = N-1\n lowerIndex = coordsLength - 1;\n middleIndex = 0;\n upperIndex = 1;\n } else { // i = 0 to N-3\n lowerIndex = i;\n middleIndex = i+1;\n upperIndex = i+2;\n }\n p1 = coords[lowerIndex];\n p2 = coords[middleIndex];\n p3 = coords[upperIndex];\n area += ( rad(p3[0]) - rad(p1[0]) ) * Math.sin( rad(p2[1]));\n }\n\n area = area * wgs84.RADIUS * wgs84.RADIUS / 2;\n }\n\n return area;\n}\n\nfunction rad(_) {\n return _ * Math.PI / 180;\n}","var polygonize = require('polygonize');\n\n/**\n * Polygonizes {@link LineString|(Multi)LineString(s)} into {@link Polygons}.\n *\n * Implementation of GEOSPolygonize function (`geos::operation::polygonize::Polygonizer`).\n *\n * Polygonizes a set of lines that represents edges in a planar graph. Edges must be correctly\n * noded, i.e., they must only meet at their endpoints. (NOTE: while TurfJS has no specific function, an easy way to\n * ensure this is to use the QGis library and call unaryUnion() on the set of input geometries and then pass the\n * result to turf-polygonize)\n *\n * The implementation correctly handles:\n *\n * - Dangles: edges which have one or both ends which are not incident on another edge endpoint.\n * - Cut Edges (bridges): edges that are connected at both ends but which do not form part of a polygon.\n *\n * @name polygonize\n * @param {FeatureCollection|Geometry|Feature} geojson Lines in order to polygonize\n * @returns {FeatureCollection} Polygons created\n * @throws {Error} if GeoJSON is invalid.\n */\nmodule.exports = function (geojson) {\n return polygonize(geojson);\n};\n","var distance = require('@turf/distance');\nvar turfBBox = require('@turf/bbox');\nvar helpers = require('@turf/helpers');\nvar inside = require('@turf/inside');\nvar invariant = require('@turf/invariant');\nvar getGeomType = invariant.getGeomType;\nvar point = helpers.point;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Creates a {@link Point} grid from a bounding box, {@link FeatureCollection} or {@link Feature}.\n *\n * @name pointGrid\n * @param {Array|FeatureCollection|Feature} bbox extent in [minX, minY, maxX, maxY] order\n * @param {number} cellSide the distance between points\n * @param {string} [units=kilometers] used in calculating cellSide, can be degrees, radians, miles, or kilometers\n * @param {boolean} [centered=true] adjust points position to center the grid into bbox. **This parameter is going to be removed** in the next major release, having the output always centered into bbox.\n * @param {boolean} [bboxIsMask=false] if true, and bbox is a Polygon or MultiPolygon, the grid Point will be created\n * only if inside the bbox Polygon(s)\n * @returns {FeatureCollection} grid of points\n * @example\n * var extent = [-70.823364, -33.553984, -70.473175, -33.302986];\n * var cellSide = 3;\n * var units = 'miles';\n *\n * var grid = turf.pointGrid(extent, cellSide, units);\n *\n * //addToMap\n * var addToMap = [grid];\n */\nmodule.exports = function (bbox, cellSide, units, centered, bboxIsMask) {\n var results = [];\n\n var bboxMask = bbox;\n // validation\n if (!bbox) throw new Error('bbox is required');\n if (!Array.isArray(bbox)) bbox = turfBBox(bbox); // Convert GeoJSON to bbox\n if (bbox.length !== 4) throw new Error('bbox must contain 4 numbers');\n\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n\n var xFraction = cellSide / (distance(point([west, south]), point([east, south]), units));\n var cellWidth = xFraction * (east - west);\n var yFraction = cellSide / (distance(point([west, south]), point([west, north]), units));\n var cellHeight = yFraction * (north - south);\n\n if (centered !== false) {\n var bboxHorizontalSide = (east - west);\n var bboxVerticalSide = (north - south);\n var columns = Math.floor(bboxHorizontalSide / cellWidth);\n var rows = Math.floor(bboxVerticalSide / cellHeight);\n // adjust origin of the grid\n var deltaX = (bboxHorizontalSide - columns * cellWidth) / 2;\n var deltaY = (bboxVerticalSide - rows * cellHeight) / 2;\n }\n\n var isPoly = !Array.isArray(bboxMask) && (getGeomType(bboxMask) === 'Polygon' || getGeomType(bboxMask) === 'MultiPolygon');\n\n var currentX = west;\n if (centered !== false) currentX += deltaX;\n while (currentX <= east) {\n var currentY = south;\n if (centered !== false) currentY += deltaY;\n while (currentY <= north) {\n var pt = point([currentX, currentY]);\n if (bboxIsMask === true && isPoly) {\n if (inside(pt, bboxMask)) {\n results.push(pt);\n }\n } else {\n results.push(pt);\n }\n currentY += cellHeight;\n }\n currentX += cellWidth;\n }\n\n return featureCollection(results);\n};\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* UTM / WGS-84 Conversion Functions (c) Chris Veness 2014-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-utm-mgrs.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-utm.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var LatLon = require('./latlon-ellipsoidal.js'); // ≡ import LatLon from 'latlon-ellipsoidal.js'\n/* eslint indent:warn */\n\n\n/**\n * Convert between Universal Transverse Mercator coordinates and WGS 84 latitude/longitude points.\n *\n * Method based on Karney 2011 ‘Transverse Mercator with an accuracy of a few nanometers’,\n * building on Krüger 1912 ‘Konforme Abbildung des Erdellipsoids in der Ebene’.\n *\n * @module utm\n * @requires latlon-ellipsoidal\n */\n\n\n/**\n * Creates a Utm coordinate object.\n *\n * @constructor\n * @param {number} zone - UTM 6° longitudinal zone (1..60 covering 180°W..180°E).\n * @param {string} hemisphere - N for northern hemisphere, S for southern hemisphere.\n * @param {number} easting - Easting in metres from false easting (-500km from central meridian).\n * @param {number} northing - Northing in metres from equator (N) or from false northing -10,000km (S).\n * @param {LatLon.datum} [datum=WGS84] - Datum UTM coordinate is based on.\n * @param {number} [convergence] - Meridian convergence (bearing of grid north clockwise from true\n * north), in degrees\n * @param {number} [scale] - Grid scale factor\n * @throws {Error} Invalid UTM coordinate\n *\n * @example\n * var utmCoord = new Utm(31, 'N', 448251, 5411932);\n */\nfunction Utm(zone, hemisphere, easting, northing, datum, convergence, scale) {\n if (!(this instanceof Utm)) { // allow instantiation without 'new'\n return new Utm(zone, hemisphere, easting, northing, datum, convergence, scale);\n }\n\n if (datum === undefined) datum = LatLon.datum.WGS84; // default if not supplied\n if (convergence === undefined) convergence = null; // default if not supplied\n if (scale === undefined) scale = null; // default if not supplied\n\n if (!(1<=zone && zone<=60)) throw new Error('Invalid UTM zone '+zone);\n if (!hemisphere.match(/[NS]/i)) throw new Error('Invalid UTM hemisphere '+hemisphere);\n // range-check easting/northing (with 40km overlap between zones) - is this worthwhile?\n //if (!(120e3<=easting && easting<=880e3)) throw new Error('Invalid UTM easting '+ easting);\n //if (!(0<=northing && northing<=10000e3)) throw new Error('Invalid UTM northing '+ northing);\n\n this.zone = Number(zone);\n this.hemisphere = hemisphere.toUpperCase();\n this.easting = Number(easting);\n this.northing = Number(northing);\n this.datum = datum;\n this.convergence = convergence===null ? null : Number(convergence);\n this.scale = scale===null ? null : Number(scale);\n}\n\n\n/**\n * Converts latitude/longitude to UTM coordinate.\n *\n * Implements Karney’s method, using Krüger series to order n^6, giving results accurate to 5nm for\n * distances up to 3900km from the central meridian.\n *\n * @returns {Utm} UTM coordinate.\n * @throws {Error} If point not valid, if point outside latitude range.\n *\n * @example\n * var latlong = new LatLon(48.8582, 2.2945);\n * var utmCoord = latlong.toUtm(); // utmCoord.toString(): '31 N 448252 5411933'\n */\nLatLon.prototype.toUtm = function() {\n if (isNaN(this.lat) || isNaN(this.lon)) throw new Error('Invalid point');\n if (!(-80<=this.lat && this.lat<=84)) throw new Error('Outside UTM limits');\n\n var falseEasting = 500e3, falseNorthing = 10000e3;\n\n var zone = Math.floor((this.lon+180)/6) + 1; // longitudinal zone\n var λ0 = ((zone-1)*6 - 180 + 3).toRadians(); // longitude of central meridian\n\n // ---- handle Norway/Svalbard exceptions\n // grid zones are 8° tall; 0°N is offset 10 into latitude bands array\n var mgrsLatBands = 'CDEFGHJKLMNPQRSTUVWXX'; // X is repeated for 80-84°N\n var latBand = mgrsLatBands.charAt(Math.floor(this.lat/8+10));\n // adjust zone & central meridian for Norway\n if (zone==31 && latBand=='V' && this.lon>= 3) { zone++; λ0 += (6).toRadians(); }\n // adjust zone & central meridian for Svalbard\n if (zone==32 && latBand=='X' && this.lon< 9) { zone--; λ0 -= (6).toRadians(); }\n if (zone==32 && latBand=='X' && this.lon>= 9) { zone++; λ0 += (6).toRadians(); }\n if (zone==34 && latBand=='X' && this.lon< 21) { zone--; λ0 -= (6).toRadians(); }\n if (zone==34 && latBand=='X' && this.lon>=21) { zone++; λ0 += (6).toRadians(); }\n if (zone==36 && latBand=='X' && this.lon< 33) { zone--; λ0 -= (6).toRadians(); }\n if (zone==36 && latBand=='X' && this.lon>=33) { zone++; λ0 += (6).toRadians(); }\n\n var φ = this.lat.toRadians(); // latitude ± from equator\n var λ = this.lon.toRadians() - λ0; // longitude ± from central meridian\n\n var a = this.datum.ellipsoid.a, f = this.datum.ellipsoid.f;\n // WGS 84: a = 6378137, b = 6356752.314245, f = 1/298.257223563;\n\n var k0 = 0.9996; // UTM scale on the central meridian\n\n // ---- easting, northing: Karney 2011 Eq 7-14, 29, 35:\n\n var e = Math.sqrt(f*(2-f)); // eccentricity\n var n = f / (2 - f); // 3rd flattening\n var n2 = n*n, n3 = n*n2, n4 = n*n3, n5 = n*n4, n6 = n*n5; // TODO: compare Horner-form accuracy?\n\n var cosλ = Math.cos(λ), sinλ = Math.sin(λ), tanλ = Math.tan(λ);\n\n var τ = Math.tan(φ); // τ ≡ tanφ, τʹ ≡ tanφʹ; prime (ʹ) indicates angles on the conformal sphere\n var σ = Math.sinh(e*Math.atanh(e*τ/Math.sqrt(1+τ*τ)));\n\n var τʹ = τ*Math.sqrt(1+σ*σ) - σ*Math.sqrt(1+τ*τ);\n\n var ξʹ = Math.atan2(τʹ, cosλ);\n var ηʹ = Math.asinh(sinλ / Math.sqrt(τʹ*τʹ + cosλ*cosλ));\n\n var A = a/(1+n) * (1 + 1/4*n2 + 1/64*n4 + 1/256*n6); // 2πA is the circumference of a meridian\n\n var α = [ null, // note α is one-based array (6th order Krüger expressions)\n 1/2*n - 2/3*n2 + 5/16*n3 + 41/180*n4 - 127/288*n5 + 7891/37800*n6,\n 13/48*n2 - 3/5*n3 + 557/1440*n4 + 281/630*n5 - 1983433/1935360*n6,\n 61/240*n3 - 103/140*n4 + 15061/26880*n5 + 167603/181440*n6,\n 49561/161280*n4 - 179/168*n5 + 6601661/7257600*n6,\n 34729/80640*n5 - 3418889/1995840*n6,\n 212378941/319334400*n6 ];\n\n var ξ = ξʹ;\n for (var j=1; j<=6; j++) ξ += α[j] * Math.sin(2*j*ξʹ) * Math.cosh(2*j*ηʹ);\n\n var η = ηʹ;\n for (var j=1; j<=6; j++) η += α[j] * Math.cos(2*j*ξʹ) * Math.sinh(2*j*ηʹ);\n\n var x = k0 * A * η;\n var y = k0 * A * ξ;\n\n // ---- convergence: Karney 2011 Eq 23, 24\n\n var pʹ = 1;\n for (var j=1; j<=6; j++) pʹ += 2*j*α[j] * Math.cos(2*j*ξʹ) * Math.cosh(2*j*ηʹ);\n var qʹ = 0;\n for (var j=1; j<=6; j++) qʹ += 2*j*α[j] * Math.sin(2*j*ξʹ) * Math.sinh(2*j*ηʹ);\n\n var γʹ = Math.atan(τʹ / Math.sqrt(1+τʹ*τʹ)*tanλ);\n var γʺ = Math.atan2(qʹ, pʹ);\n\n var γ = γʹ + γʺ;\n\n // ---- scale: Karney 2011 Eq 25\n\n var sinφ = Math.sin(φ);\n var kʹ = Math.sqrt(1 - e*e*sinφ*sinφ) * Math.sqrt(1 + τ*τ) / Math.sqrt(τʹ*τʹ + cosλ*cosλ);\n var kʺ = A / a * Math.sqrt(pʹ*pʹ + qʹ*qʹ);\n\n var k = k0 * kʹ * kʺ;\n\n // ------------\n\n // shift x/y to false origins\n x = x + falseEasting; // make x relative to false easting\n if (y < 0) y = y + falseNorthing; // make y in southern hemisphere relative to false northing\n\n // round to reasonable precision\n x = Number(x.toFixed(6)); // nm precision\n y = Number(y.toFixed(6)); // nm precision\n var convergence = Number(γ.toDegrees().toFixed(9));\n var scale = Number(k.toFixed(12));\n\n var h = this.lat>=0 ? 'N' : 'S'; // hemisphere\n\n return new Utm(zone, h, x, y, this.datum, convergence, scale);\n};\n\n\n/**\n * Converts UTM zone/easting/northing coordinate to latitude/longitude\n *\n * @param {Utm} utmCoord - UTM coordinate to be converted to latitude/longitude.\n * @returns {LatLon} Latitude/longitude of supplied grid reference.\n *\n * @example\n * var grid = new Utm(31, 'N', 448251.795, 5411932.678);\n * var latlong = grid.toLatLonE(); // latlong.toString(): 48°51′29.52″N, 002°17′40.20″E\n */\nUtm.prototype.toLatLonE = function() {\n var z = this.zone;\n var h = this.hemisphere;\n var x = this.easting;\n var y = this.northing;\n\n if (isNaN(z) || isNaN(x) || isNaN(y)) throw new Error('Invalid coordinate');\n\n var falseEasting = 500e3, falseNorthing = 10000e3;\n\n var a = this.datum.ellipsoid.a, f = this.datum.ellipsoid.f;\n // WGS 84: a = 6378137, b = 6356752.314245, f = 1/298.257223563;\n\n var k0 = 0.9996; // UTM scale on the central meridian\n\n x = x - falseEasting; // make x ± relative to central meridian\n y = h=='S' ? y - falseNorthing : y; // make y ± relative to equator\n\n // ---- from Karney 2011 Eq 15-22, 36:\n\n var e = Math.sqrt(f*(2-f)); // eccentricity\n var n = f / (2 - f); // 3rd flattening\n var n2 = n*n, n3 = n*n2, n4 = n*n3, n5 = n*n4, n6 = n*n5;\n\n var A = a/(1+n) * (1 + 1/4*n2 + 1/64*n4 + 1/256*n6); // 2πA is the circumference of a meridian\n\n var η = x / (k0*A);\n var ξ = y / (k0*A);\n\n var β = [ null, // note β is one-based array (6th order Krüger expressions)\n 1/2*n - 2/3*n2 + 37/96*n3 - 1/360*n4 - 81/512*n5 + 96199/604800*n6,\n 1/48*n2 + 1/15*n3 - 437/1440*n4 + 46/105*n5 - 1118711/3870720*n6,\n 17/480*n3 - 37/840*n4 - 209/4480*n5 + 5569/90720*n6,\n 4397/161280*n4 - 11/504*n5 - 830251/7257600*n6,\n 4583/161280*n5 - 108847/3991680*n6,\n 20648693/638668800*n6 ];\n\n var ξʹ = ξ;\n for (var j=1; j<=6; j++) ξʹ -= β[j] * Math.sin(2*j*ξ) * Math.cosh(2*j*η);\n\n var ηʹ = η;\n for (var j=1; j<=6; j++) ηʹ -= β[j] * Math.cos(2*j*ξ) * Math.sinh(2*j*η);\n\n var sinhηʹ = Math.sinh(ηʹ);\n var sinξʹ = Math.sin(ξʹ), cosξʹ = Math.cos(ξʹ);\n\n var τʹ = sinξʹ / Math.sqrt(sinhηʹ*sinhηʹ + cosξʹ*cosξʹ);\n\n var τi = τʹ;\n do {\n var σi = Math.sinh(e*Math.atanh(e*τi/Math.sqrt(1+τi*τi)));\n var τiʹ = τi * Math.sqrt(1+σi*σi) - σi * Math.sqrt(1+τi*τi);\n var δτi = (τʹ - τiʹ)/Math.sqrt(1+τiʹ*τiʹ)\n * (1 + (1-e*e)*τi*τi) / ((1-e*e)*Math.sqrt(1+τi*τi));\n τi += δτi;\n } while (Math.abs(δτi) > 1e-12); // using IEEE 754 δτi -> 0 after 2-3 iterations\n // note relatively large convergence test as δτi toggles on ±1.12e-16 for eg 31 N 400000 5000000\n var τ = τi;\n\n var φ = Math.atan(τ);\n\n var λ = Math.atan2(sinhηʹ, cosξʹ);\n\n // ---- convergence: Karney 2011 Eq 26, 27\n\n var p = 1;\n for (var j=1; j<=6; j++) p -= 2*j*β[j] * Math.cos(2*j*ξ) * Math.cosh(2*j*η);\n var q = 0;\n for (var j=1; j<=6; j++) q += 2*j*β[j] * Math.sin(2*j*ξ) * Math.sinh(2*j*η);\n\n var γʹ = Math.atan(Math.tan(ξʹ) * Math.tanh(ηʹ));\n var γʺ = Math.atan2(q, p);\n\n var γ = γʹ + γʺ;\n\n // ---- scale: Karney 2011 Eq 28\n\n var sinφ = Math.sin(φ);\n var kʹ = Math.sqrt(1 - e*e*sinφ*sinφ) * Math.sqrt(1 + τ*τ) * Math.sqrt(sinhηʹ*sinhηʹ + cosξʹ*cosξʹ);\n var kʺ = A / a / Math.sqrt(p*p + q*q);\n\n var k = k0 * kʹ * kʺ;\n\n // ------------\n\n var λ0 = ((z-1)*6 - 180 + 3).toRadians(); // longitude of central meridian\n λ += λ0; // move λ from zonal to global coordinates\n\n // round to reasonable precision\n var lat = Number(φ.toDegrees().toFixed(11)); // nm precision (1nm = 10^-11°)\n var lon = Number(λ.toDegrees().toFixed(11)); // (strictly lat rounding should be φ⋅cosφ!)\n var convergence = Number(γ.toDegrees().toFixed(9));\n var scale = Number(k.toFixed(12));\n\n var latLong = new LatLon(lat, lon, this.datum);\n // ... and add the convergence and scale into the LatLon object ... wonderful JavaScript!\n latLong.convergence = convergence;\n latLong.scale = scale;\n\n return latLong;\n};\n\n\n/**\n * Parses string representation of UTM coordinate.\n *\n * A UTM coordinate comprises (space-separated)\n * - zone\n * - hemisphere\n * - easting\n * - northing.\n *\n * @param {string} utmCoord - UTM coordinate (WGS 84).\n * @param {Datum} [datum=WGS84] - Datum coordinate is defined in (default WGS 84).\n * @returns {Utm}\n * @throws {Error} Invalid UTM coordinate.\n *\n * @example\n * var utmCoord = Utm.parse('31 N 448251 5411932');\n * // utmCoord: {zone: 31, hemisphere: 'N', easting: 448251, northing: 5411932 }\n */\nUtm.parse = function(utmCoord, datum) {\n if (datum === undefined) datum = LatLon.datum.WGS84; // default if not supplied\n\n // match separate elements (separated by whitespace)\n utmCoord = utmCoord.trim().match(/\\S+/g);\n\n if (utmCoord==null || utmCoord.length!=4) throw new Error('Invalid UTM coordinate ‘'+utmCoord+'’');\n\n var zone = utmCoord[0], hemisphere = utmCoord[1], easting = utmCoord[2], northing = utmCoord[3];\n\n return new Utm(zone, hemisphere, easting, northing, datum);\n};\n\n\n/**\n * Returns a string representation of a UTM coordinate.\n *\n * To distinguish from MGRS grid zone designators, a space is left between the zone and the\n * hemisphere.\n *\n * Note that UTM coordinates get rounded, not truncated (unlike MGRS grid references).\n *\n * @param {number} [digits=0] - Number of digits to appear after the decimal point (3 ≡ mm).\n * @returns {string} A string representation of the coordinate.\n *\n * @example\n * var utm = Utm.parse('31 N 448251 5411932').toString(4); // 31 N 448251.0000 5411932.0000\n */\nUtm.prototype.toString = function(digits) {\n digits = Number(digits||0); // default 0 if not supplied\n\n var z = this.zone<10 ? '0'+this.zone : this.zone; // leading zero\n var h = this.hemisphere;\n var e = this.easting;\n var n = this.northing;\n if (isNaN(z) || !h.match(/[NS]/) || isNaN(e) || isNaN(n)) return '';\n\n return z+' '+h+' '+e.toFixed(digits)+' '+n.toFixed(digits);\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n/** Polyfill Math.sinh for old browsers / IE */\nif (Math.sinh === undefined) {\n Math.sinh = function(x) {\n return (Math.exp(x) - Math.exp(-x)) / 2;\n };\n}\n\n/** Polyfill Math.cosh for old browsers / IE */\nif (Math.cosh === undefined) {\n Math.cosh = function(x) {\n return (Math.exp(x) + Math.exp(-x)) / 2;\n };\n}\n\n/** Polyfill Math.tanh for old browsers / IE */\nif (Math.tanh === undefined) {\n Math.tanh = function(x) {\n return (Math.exp(x) - Math.exp(-x)) / (Math.exp(x) + Math.exp(-x));\n };\n}\n\n/** Polyfill Math.asinh for old browsers / IE */\nif (Math.asinh === undefined) {\n Math.asinh = function(x) {\n return Math.log(x + Math.sqrt(1 + x*x));\n };\n}\n\n/** Polyfill Math.atanh for old browsers / IE */\nif (Math.atanh === undefined) {\n Math.atanh = function(x) {\n return Math.log((1+x) / (1-x)) / 2;\n };\n}\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = Utm; // ≡ export default Utm\n","var each = require('@turf/meta').coordEach,\n convexHull = require('convex-hull'),\n polygon = require('@turf/helpers').polygon;\n\n/**\n * Takes a {@link Feature} or a {@link FeatureCollection} and returns a convex hull {@link Polygon}.\n *\n * Internally this uses\n * the [convex-hull](https://github.com/mikolalysenko/convex-hull) module that\n * implements a [monotone chain hull](http://en.wikibooks.org/wiki/Algorithm_Implementation/Geometry/Convex_hull/Monotone_chain).\n *\n * @name convex\n * @param {Feature|FeatureCollection} feature input Feature or FeatureCollection\n * @returns {Feature} a convex hull\n * @example\n * var points = turf.featureCollection([\n * turf.point([10.195312, 43.755225]),\n * turf.point([10.404052, 43.8424511]),\n * turf.point([10.579833, 43.659924]),\n * turf.point([10.360107, 43.516688]),\n * turf.point([10.14038, 43.588348]),\n * turf.point([10.195312, 43.755225])\n * ]);\n *\n * var hull = turf.convex(points);\n *\n * //addToMap\n * var addToMap = [points, hull]\n */\nmodule.exports = function (feature) {\n var points = [];\n\n // Remove Z in coordinates because it breaks the convexHull algorithm\n each(feature, function (coord) {\n points.push([coord[0], coord[1]]);\n });\n\n var hull = convexHull(points);\n\n // Hull should have at least 3 different vertices in order to create a valid polygon\n if (hull.length >= 3) {\n var ring = [];\n for (var i = 0; i < hull.length; i++) {\n ring.push(points[hull[i][0]]);\n }\n ring.push(points[hull[hull.length - 1][1]]);\n return polygon([ring]);\n }\n return undefined;\n};\n","// Adds floating point numbers with twice the normal precision.\n// Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and\n// Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)\n// 305–363 (1997).\n// Code adapted from GeographicLib by Charles F. F. Karney,\n// http://geographiclib.sourceforge.net/\n\nexport default function() {\n return new Adder;\n}\n\nfunction Adder() {\n this.reset();\n}\n\nAdder.prototype = {\n constructor: Adder,\n reset: function() {\n this.s = // rounded value\n this.t = 0; // exact error\n },\n add: function(y) {\n add(temp, y, this.t);\n add(this, temp.s, this.s);\n if (this.s) this.t += temp.t;\n else this.s = temp.t;\n },\n valueOf: function() {\n return this.s;\n }\n};\n\nvar temp = new Adder;\n\nfunction add(adder, a, b) {\n var x = adder.s = a + b,\n bv = x - a,\n av = x - bv;\n adder.t = (a - av) + (b - bv);\n}\n","export var epsilon = 1e-6;\nexport var epsilon2 = 1e-12;\nexport var pi = Math.PI;\nexport var halfPi = pi / 2;\nexport var quarterPi = pi / 4;\nexport var tau = pi * 2;\n\nexport var degrees = 180 / pi;\nexport var radians = pi / 180;\n\nexport var abs = Math.abs;\nexport var atan = Math.atan;\nexport var atan2 = Math.atan2;\nexport var cos = Math.cos;\nexport var ceil = Math.ceil;\nexport var exp = Math.exp;\nexport var floor = Math.floor;\nexport var log = Math.log;\nexport var pow = Math.pow;\nexport var sin = Math.sin;\nexport var sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\nexport var sqrt = Math.sqrt;\nexport var tan = Math.tan;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x > 1 ? halfPi : x < -1 ? -halfPi : Math.asin(x);\n}\n\nexport function haversin(x) {\n return (x = sin(x / 2)) * x;\n}\n","export default function noop() {}\n","function streamGeometry(geometry, stream) {\n if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n streamGeometryType[geometry.type](geometry, stream);\n }\n}\n\nvar streamObjectType = {\n Feature: function(object, stream) {\n streamGeometry(object.geometry, stream);\n },\n FeatureCollection: function(object, stream) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) streamGeometry(features[i].geometry, stream);\n }\n};\n\nvar streamGeometryType = {\n Sphere: function(object, stream) {\n stream.sphere();\n },\n Point: function(object, stream) {\n object = object.coordinates;\n stream.point(object[0], object[1], object[2]);\n },\n MultiPoint: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n },\n LineString: function(object, stream) {\n streamLine(object.coordinates, stream, 0);\n },\n MultiLineString: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamLine(coordinates[i], stream, 0);\n },\n Polygon: function(object, stream) {\n streamPolygon(object.coordinates, stream);\n },\n MultiPolygon: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamPolygon(coordinates[i], stream);\n },\n GeometryCollection: function(object, stream) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) streamGeometry(geometries[i], stream);\n }\n};\n\nfunction streamLine(coordinates, stream, closed) {\n var i = -1, n = coordinates.length - closed, coordinate;\n stream.lineStart();\n while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n stream.lineEnd();\n}\n\nfunction streamPolygon(coordinates, stream) {\n var i = -1, n = coordinates.length;\n stream.polygonStart();\n while (++i < n) streamLine(coordinates[i], stream, 1);\n stream.polygonEnd();\n}\n\nexport default function(object, stream) {\n if (object && streamObjectType.hasOwnProperty(object.type)) {\n streamObjectType[object.type](object, stream);\n } else {\n streamGeometry(object, stream);\n }\n}\n","import adder from \"./adder\";\nimport {atan2, cos, quarterPi, radians, sin, tau} from \"./math\";\nimport noop from \"./noop\";\nimport stream from \"./stream\";\n\nexport var areaRingSum = adder();\n\nvar areaSum = adder(),\n lambda00,\n phi00,\n lambda0,\n cosPhi0,\n sinPhi0;\n\nexport var areaStream = {\n point: noop,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: function() {\n areaRingSum.reset();\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n var areaRing = +areaRingSum;\n areaSum.add(areaRing < 0 ? tau + areaRing : areaRing);\n this.lineStart = this.lineEnd = this.point = noop;\n },\n sphere: function() {\n areaSum.add(tau);\n }\n};\n\nfunction areaRingStart() {\n areaStream.point = areaPointFirst;\n}\n\nfunction areaRingEnd() {\n areaPoint(lambda00, phi00);\n}\n\nfunction areaPointFirst(lambda, phi) {\n areaStream.point = areaPoint;\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n lambda0 = lambda, cosPhi0 = cos(phi = phi / 2 + quarterPi), sinPhi0 = sin(phi);\n}\n\nfunction areaPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n phi = phi / 2 + quarterPi; // half the angular distance from south pole\n\n // Spherical excess E for a spherical triangle with vertices: south pole,\n // previous point, current point. Uses a formula derived from Cagnoli’s\n // theorem. See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).\n var dLambda = lambda - lambda0,\n sdLambda = dLambda >= 0 ? 1 : -1,\n adLambda = sdLambda * dLambda,\n cosPhi = cos(phi),\n sinPhi = sin(phi),\n k = sinPhi0 * sinPhi,\n u = cosPhi0 * cosPhi + k * cos(adLambda),\n v = k * sdLambda * sin(adLambda);\n areaRingSum.add(atan2(v, u));\n\n // Advance the previous points.\n lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;\n}\n\nexport default function(object) {\n areaSum.reset();\n stream(object, areaStream);\n return areaSum * 2;\n}\n","import {asin, atan2, cos, sin, sqrt} from \"./math\";\n\nexport function spherical(cartesian) {\n return [atan2(cartesian[1], cartesian[0]), asin(cartesian[2])];\n}\n\nexport function cartesian(spherical) {\n var lambda = spherical[0], phi = spherical[1], cosPhi = cos(phi);\n return [cosPhi * cos(lambda), cosPhi * sin(lambda), sin(phi)];\n}\n\nexport function cartesianDot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n\nexport function cartesianCross(a, b) {\n return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n}\n\n// TODO return a\nexport function cartesianAddInPlace(a, b) {\n a[0] += b[0], a[1] += b[1], a[2] += b[2];\n}\n\nexport function cartesianScale(vector, k) {\n return [vector[0] * k, vector[1] * k, vector[2] * k];\n}\n\n// TODO return d\nexport function cartesianNormalizeInPlace(d) {\n var l = sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n d[0] /= l, d[1] /= l, d[2] /= l;\n}\n","import adder from \"./adder\";\nimport {areaStream, areaRingSum} from \"./area\";\nimport {cartesian, cartesianCross, cartesianNormalizeInPlace, spherical} from \"./cartesian\";\nimport {abs, degrees, epsilon, radians} from \"./math\";\nimport stream from \"./stream\";\n\nvar lambda0, phi0, lambda1, phi1, // bounds\n lambda2, // previous lambda-coordinate\n lambda00, phi00, // first point\n p0, // previous 3D point\n deltaSum = adder(),\n ranges,\n range;\n\nvar boundsStream = {\n point: boundsPoint,\n lineStart: boundsLineStart,\n lineEnd: boundsLineEnd,\n polygonStart: function() {\n boundsStream.point = boundsRingPoint;\n boundsStream.lineStart = boundsRingStart;\n boundsStream.lineEnd = boundsRingEnd;\n deltaSum.reset();\n areaStream.polygonStart();\n },\n polygonEnd: function() {\n areaStream.polygonEnd();\n boundsStream.point = boundsPoint;\n boundsStream.lineStart = boundsLineStart;\n boundsStream.lineEnd = boundsLineEnd;\n if (areaRingSum < 0) lambda0 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n else if (deltaSum > epsilon) phi1 = 90;\n else if (deltaSum < -epsilon) phi0 = -90;\n range[0] = lambda0, range[1] = lambda1;\n }\n};\n\nfunction boundsPoint(lambda, phi) {\n ranges.push(range = [lambda0 = lambda, lambda1 = lambda]);\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n}\n\nfunction linePoint(lambda, phi) {\n var p = cartesian([lambda * radians, phi * radians]);\n if (p0) {\n var normal = cartesianCross(p0, p),\n equatorial = [normal[1], -normal[0], 0],\n inflection = cartesianCross(equatorial, normal);\n cartesianNormalizeInPlace(inflection);\n inflection = spherical(inflection);\n var delta = lambda - lambda2,\n sign = delta > 0 ? 1 : -1,\n lambdai = inflection[0] * degrees * sign,\n phii,\n antimeridian = abs(delta) > 180;\n if (antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = inflection[1] * degrees;\n if (phii > phi1) phi1 = phii;\n } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = -inflection[1] * degrees;\n if (phii < phi0) phi0 = phii;\n } else {\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n if (antimeridian) {\n if (lambda < lambda2) {\n if (angle(lambda0, lambda) > angle(lambda0, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0, lambda1)) lambda0 = lambda;\n }\n } else {\n if (lambda1 >= lambda0) {\n if (lambda < lambda0) lambda0 = lambda;\n if (lambda > lambda1) lambda1 = lambda;\n } else {\n if (lambda > lambda2) {\n if (angle(lambda0, lambda) > angle(lambda0, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0, lambda1)) lambda0 = lambda;\n }\n }\n }\n } else {\n ranges.push(range = [lambda0 = lambda, lambda1 = lambda]);\n }\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n p0 = p, lambda2 = lambda;\n}\n\nfunction boundsLineStart() {\n boundsStream.point = linePoint;\n}\n\nfunction boundsLineEnd() {\n range[0] = lambda0, range[1] = lambda1;\n boundsStream.point = boundsPoint;\n p0 = null;\n}\n\nfunction boundsRingPoint(lambda, phi) {\n if (p0) {\n var delta = lambda - lambda2;\n deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);\n } else {\n lambda00 = lambda, phi00 = phi;\n }\n areaStream.point(lambda, phi);\n linePoint(lambda, phi);\n}\n\nfunction boundsRingStart() {\n areaStream.lineStart();\n}\n\nfunction boundsRingEnd() {\n boundsRingPoint(lambda00, phi00);\n areaStream.lineEnd();\n if (abs(deltaSum) > epsilon) lambda0 = -(lambda1 = 180);\n range[0] = lambda0, range[1] = lambda1;\n p0 = null;\n}\n\n// Finds the left-right distance between two longitudes.\n// This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want\n// the distance between ±180° to be 360°.\nfunction angle(lambda0, lambda1) {\n return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;\n}\n\nfunction rangeCompare(a, b) {\n return a[0] - b[0];\n}\n\nfunction rangeContains(range, x) {\n return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;\n}\n\nexport default function(feature) {\n var i, n, a, b, merged, deltaMax, delta;\n\n phi1 = lambda1 = -(lambda0 = phi0 = Infinity);\n ranges = [];\n stream(feature, boundsStream);\n\n // First, sort ranges by their minimum longitudes.\n if (n = ranges.length) {\n ranges.sort(rangeCompare);\n\n // Then, merge any ranges that overlap.\n for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {\n b = ranges[i];\n if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {\n if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];\n if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];\n } else {\n merged.push(a = b);\n }\n }\n\n // Finally, find the largest gap between the merged ranges.\n // The final bounding box will be the inverse of this gap.\n for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {\n b = merged[i];\n if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0 = b[0], lambda1 = a[1];\n }\n }\n\n ranges = range = null;\n\n return lambda0 === Infinity || phi0 === Infinity\n ? [[NaN, NaN], [NaN, NaN]]\n : [[lambda0, phi0], [lambda1, phi1]];\n}\n","import {asin, atan2, cos, degrees, epsilon, epsilon2, radians, sin, sqrt} from \"./math\";\nimport noop from \"./noop\";\nimport stream from \"./stream\";\n\nvar W0, W1,\n X0, Y0, Z0,\n X1, Y1, Z1,\n X2, Y2, Z2,\n lambda00, phi00, // first point\n x0, y0, z0; // previous point\n\nvar centroidStream = {\n sphere: noop,\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n }\n};\n\n// Arithmetic mean of Cartesian vectors.\nfunction centroidPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi);\n centroidPointCartesian(cosPhi * cos(lambda), cosPhi * sin(lambda), sin(phi));\n}\n\nfunction centroidPointCartesian(x, y, z) {\n ++W0;\n X0 += (x - X0) / W0;\n Y0 += (y - Y0) / W0;\n Z0 += (z - Z0) / W0;\n}\n\nfunction centroidLineStart() {\n centroidStream.point = centroidLinePointFirst;\n}\n\nfunction centroidLinePointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi);\n x0 = cosPhi * cos(lambda);\n y0 = cosPhi * sin(lambda);\n z0 = sin(phi);\n centroidStream.point = centroidLinePoint;\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLinePoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi),\n x = cosPhi * cos(lambda),\n y = cosPhi * sin(lambda),\n z = sin(phi),\n w = atan2(sqrt((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLineEnd() {\n centroidStream.point = centroidPoint;\n}\n\n// See J. E. Brock, The Inertia Tensor for a Spherical Triangle,\n// J. Applied Mechanics 42, 239 (1975).\nfunction centroidRingStart() {\n centroidStream.point = centroidRingPointFirst;\n}\n\nfunction centroidRingEnd() {\n centroidRingPoint(lambda00, phi00);\n centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingPointFirst(lambda, phi) {\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n centroidStream.point = centroidRingPoint;\n var cosPhi = cos(phi);\n x0 = cosPhi * cos(lambda);\n y0 = cosPhi * sin(lambda);\n z0 = sin(phi);\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidRingPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi),\n x = cosPhi * cos(lambda),\n y = cosPhi * sin(lambda),\n z = sin(phi),\n cx = y0 * z - z0 * y,\n cy = z0 * x - x0 * z,\n cz = x0 * y - y0 * x,\n m = sqrt(cx * cx + cy * cy + cz * cz),\n w = asin(m), // line weight = angle\n v = m && -w / m; // area weight multiplier\n X2 += v * cx;\n Y2 += v * cy;\n Z2 += v * cz;\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n}\n\nexport default function(object) {\n W0 = W1 =\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n stream(object, centroidStream);\n\n var x = X2,\n y = Y2,\n z = Z2,\n m = x * x + y * y + z * z;\n\n // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.\n if (m < epsilon2) {\n x = X1, y = Y1, z = Z1;\n // If the feature has zero length, fall back to arithmetic mean of point vectors.\n if (W1 < epsilon) x = X0, y = Y0, z = Z0;\n m = x * x + y * y + z * z;\n // If the feature still has an undefined ccentroid, then return.\n if (m < epsilon2) return [NaN, NaN];\n }\n\n return [atan2(y, x) * degrees, asin(z / sqrt(m)) * degrees];\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","export default function(a, b) {\n\n function compose(x, y) {\n return x = a(x, y), b(x[0], x[1]);\n }\n\n if (a.invert && b.invert) compose.invert = function(x, y) {\n return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n };\n\n return compose;\n}\n","import compose from \"./compose\";\nimport {abs, asin, atan2, cos, degrees, pi, radians, sin, tau} from \"./math\";\n\nfunction rotationIdentity(lambda, phi) {\n return [abs(lambda) > pi ? lambda + Math.round(-lambda / tau) * tau : lambda, phi];\n}\n\nrotationIdentity.invert = rotationIdentity;\n\nexport function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n return (deltaLambda %= tau) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n : rotationLambda(deltaLambda))\n : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n : rotationIdentity);\n}\n\nfunction forwardRotationLambda(deltaLambda) {\n return function(lambda, phi) {\n return lambda += deltaLambda, [lambda > pi ? lambda - tau : lambda < -pi ? lambda + tau : lambda, phi];\n };\n}\n\nfunction rotationLambda(deltaLambda) {\n var rotation = forwardRotationLambda(deltaLambda);\n rotation.invert = forwardRotationLambda(-deltaLambda);\n return rotation;\n}\n\nfunction rotationPhiGamma(deltaPhi, deltaGamma) {\n var cosDeltaPhi = cos(deltaPhi),\n sinDeltaPhi = sin(deltaPhi),\n cosDeltaGamma = cos(deltaGamma),\n sinDeltaGamma = sin(deltaGamma);\n\n function rotation(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaPhi + x * sinDeltaPhi;\n return [\n atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n asin(k * cosDeltaGamma + y * sinDeltaGamma)\n ];\n }\n\n rotation.invert = function(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaGamma - y * sinDeltaGamma;\n return [\n atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n asin(k * cosDeltaPhi - x * sinDeltaPhi)\n ];\n };\n\n return rotation;\n}\n\nexport default function(rotate) {\n rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n function forward(coordinates) {\n coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n }\n\n forward.invert = function(coordinates) {\n coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n };\n\n return forward;\n}\n","import {cartesian, cartesianNormalizeInPlace, spherical} from \"./cartesian\";\nimport constant from \"./constant\";\nimport {acos, cos, degrees, epsilon, radians, sin, tau} from \"./math\";\nimport {rotateRadians} from \"./rotation\";\n\n// Generates a circle centered at [0°, 0°], with a given radius and precision.\nexport function circleStream(stream, radius, delta, direction, t0, t1) {\n if (!delta) return;\n var cosRadius = cos(radius),\n sinRadius = sin(radius),\n step = direction * delta;\n if (t0 == null) {\n t0 = radius + direction * tau;\n t1 = radius - step / 2;\n } else {\n t0 = circleRadius(cosRadius, t0);\n t1 = circleRadius(cosRadius, t1);\n if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau;\n }\n for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n point = spherical([cosRadius, -sinRadius * cos(t), -sinRadius * sin(t)]);\n stream.point(point[0], point[1]);\n }\n}\n\n// Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\nfunction circleRadius(cosRadius, point) {\n point = cartesian(point), point[0] -= cosRadius;\n cartesianNormalizeInPlace(point);\n var radius = acos(-point[1]);\n return ((-point[2] < 0 ? -radius : radius) + tau - epsilon) % tau;\n}\n\nexport default function() {\n var center = constant([0, 0]),\n radius = constant(90),\n precision = constant(6),\n ring,\n rotate,\n stream = {point: point};\n\n function point(x, y) {\n ring.push(x = rotate(x, y));\n x[0] *= degrees, x[1] *= degrees;\n }\n\n function circle() {\n var c = center.apply(this, arguments),\n r = radius.apply(this, arguments) * radians,\n p = precision.apply(this, arguments) * radians;\n ring = [];\n rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n circleStream(stream, r, p, 1);\n c = {type: \"Polygon\", coordinates: [ring]};\n ring = rotate = null;\n return c;\n }\n\n circle.center = function(_) {\n return arguments.length ? (center = typeof _ === \"function\" ? _ : constant([+_[0], +_[1]]), circle) : center;\n };\n\n circle.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), circle) : radius;\n };\n\n circle.precision = function(_) {\n return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant(+_), circle) : precision;\n };\n\n return circle;\n}\n","import noop from \"../noop\";\n\nexport default function() {\n var lines = [],\n line;\n return {\n point: function(x, y) {\n line.push([x, y]);\n },\n lineStart: function() {\n lines.push(line = []);\n },\n lineEnd: noop,\n rejoin: function() {\n if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n },\n result: function() {\n var result = lines;\n lines = [];\n line = null;\n return result;\n }\n };\n}\n","import {abs, epsilon} from \"./math\";\n\nexport default function(a, b) {\n return abs(a[0] - b[0]) < epsilon && abs(a[1] - b[1]) < epsilon;\n}\n","import pointEqual from \"../pointEqual\";\n\nfunction Intersection(point, points, other, entry) {\n this.x = point;\n this.z = points;\n this.o = other; // another intersection\n this.e = entry; // is an entry?\n this.v = false; // visited\n this.n = this.p = null; // next & previous\n}\n\n// A generalized polygon clipping algorithm: given a polygon that has been cut\n// into its visible line segments, and rejoins the segments by interpolating\n// along the clip edge.\nexport default function(segments, compareIntersection, startInside, interpolate, stream) {\n var subject = [],\n clip = [],\n i,\n n;\n\n segments.forEach(function(segment) {\n if ((n = segment.length - 1) <= 0) return;\n var n, p0 = segment[0], p1 = segment[n], x;\n\n // If the first and last points of a segment are coincident, then treat as a\n // closed ring. TODO if all rings are closed, then the winding order of the\n // exterior ring should be checked.\n if (pointEqual(p0, p1)) {\n stream.lineStart();\n for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n stream.lineEnd();\n return;\n }\n\n subject.push(x = new Intersection(p0, segment, null, true));\n clip.push(x.o = new Intersection(p0, null, x, false));\n subject.push(x = new Intersection(p1, segment, null, false));\n clip.push(x.o = new Intersection(p1, null, x, true));\n });\n\n if (!subject.length) return;\n\n clip.sort(compareIntersection);\n link(subject);\n link(clip);\n\n for (i = 0, n = clip.length; i < n; ++i) {\n clip[i].e = startInside = !startInside;\n }\n\n var start = subject[0],\n points,\n point;\n\n while (1) {\n // Find first unvisited intersection.\n var current = start,\n isSubject = true;\n while (current.v) if ((current = current.n) === start) return;\n points = current.z;\n stream.lineStart();\n do {\n current.v = current.o.v = true;\n if (current.e) {\n if (isSubject) {\n for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.n.x, 1, stream);\n }\n current = current.n;\n } else {\n if (isSubject) {\n points = current.p.z;\n for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.p.x, -1, stream);\n }\n current = current.p;\n }\n current = current.o;\n points = current.z;\n isSubject = !isSubject;\n } while (!current.v);\n stream.lineEnd();\n }\n}\n\nfunction link(array) {\n if (!(n = array.length)) return;\n var n,\n i = 0,\n a = array[0],\n b;\n while (++i < n) {\n a.n = b = array[i];\n b.p = a;\n a = b;\n }\n a.n = b = array[0];\n b.p = a;\n}\n","import adder from \"./adder\";\nimport {cartesian, cartesianCross, cartesianNormalizeInPlace} from \"./cartesian\";\nimport {asin, atan2, cos, epsilon, halfPi, pi, quarterPi, sin, tau} from \"./math\";\n\nvar sum = adder();\n\nexport default function(polygon, point) {\n var lambda = point[0],\n phi = point[1],\n sinPhi = sin(phi),\n normal = [sin(lambda), -cos(lambda), 0],\n angle = 0,\n winding = 0;\n\n sum.reset();\n\n if (sinPhi === 1) phi = halfPi + epsilon;\n else if (sinPhi === -1) phi = -halfPi - epsilon;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n if (!(m = (ring = polygon[i]).length)) continue;\n var ring,\n m,\n point0 = ring[m - 1],\n lambda0 = point0[0],\n phi0 = point0[1] / 2 + quarterPi,\n sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0);\n\n for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n var point1 = ring[j],\n lambda1 = point1[0],\n phi1 = point1[1] / 2 + quarterPi,\n sinPhi1 = sin(phi1),\n cosPhi1 = cos(phi1),\n delta = lambda1 - lambda0,\n sign = delta >= 0 ? 1 : -1,\n absDelta = sign * delta,\n antimeridian = absDelta > pi,\n k = sinPhi0 * sinPhi1;\n\n sum.add(atan2(k * sign * sin(absDelta), cosPhi0 * cosPhi1 + k * cos(absDelta)));\n angle += antimeridian ? delta + sign * tau : delta;\n\n // Are the longitudes either side of the point’s meridian (lambda),\n // and are the latitudes smaller than the parallel (phi)?\n if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n var arc = cartesianCross(cartesian(point0), cartesian(point1));\n cartesianNormalizeInPlace(arc);\n var intersection = cartesianCross(normal, arc);\n cartesianNormalizeInPlace(intersection);\n var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin(intersection[2]);\n if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n winding += antimeridian ^ delta >= 0 ? 1 : -1;\n }\n }\n }\n }\n\n // First, determine whether the South pole is inside or outside:\n //\n // It is inside if:\n // * the polygon winds around it in a clockwise direction.\n // * the polygon does not (cumulatively) wind around it, but has a negative\n // (counter-clockwise) area.\n //\n // Second, count the (signed) number of times a segment crosses a lambda\n // from the point to the South pole. If it is zero, then the point is the\n // same side as the South pole.\n\n return (angle < -epsilon || angle < epsilon && sum < -epsilon) ^ (winding & 1);\n}\n","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","export default function(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n}\n","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 default function(values) {\n return Math.ceil(Math.log(values.length) / Math.LN2) + 1;\n}\n","export default function(arrays) {\n var n = arrays.length,\n m,\n i = -1,\n j = 0,\n merged,\n array;\n\n while (++i < n) j += arrays[i].length;\n merged = new Array(j);\n\n while (--n >= 0) {\n array = arrays[n];\n m = array.length;\n while (--m >= 0) {\n merged[--j] = array[m];\n }\n }\n\n return merged;\n}\n","import transpose from \"./transpose\";\n\nexport default function() {\n return transpose(arguments);\n}\n","import clipBuffer from \"./buffer\";\nimport clipRejoin from \"./rejoin\";\nimport {epsilon, halfPi} from \"../math\";\nimport polygonContains from \"../polygonContains\";\nimport {merge} from \"d3-array\";\n\nexport default function(pointVisible, clipLine, interpolate, start) {\n return function(sink) {\n var line = clipLine(sink),\n ringBuffer = clipBuffer(),\n ringSink = clipLine(ringBuffer),\n polygonStarted = false,\n polygon,\n segments,\n ring;\n\n var clip = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n clip.point = pointRing;\n clip.lineStart = ringStart;\n clip.lineEnd = ringEnd;\n segments = [];\n polygon = [];\n },\n polygonEnd: function() {\n clip.point = point;\n clip.lineStart = lineStart;\n clip.lineEnd = lineEnd;\n segments = merge(segments);\n var startInside = polygonContains(polygon, start);\n if (segments.length) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n clipRejoin(segments, compareIntersection, startInside, interpolate, sink);\n } else if (startInside) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n }\n if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n segments = polygon = null;\n },\n sphere: function() {\n sink.polygonStart();\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n sink.polygonEnd();\n }\n };\n\n function point(lambda, phi) {\n if (pointVisible(lambda, phi)) sink.point(lambda, phi);\n }\n\n function pointLine(lambda, phi) {\n line.point(lambda, phi);\n }\n\n function lineStart() {\n clip.point = pointLine;\n line.lineStart();\n }\n\n function lineEnd() {\n clip.point = point;\n line.lineEnd();\n }\n\n function pointRing(lambda, phi) {\n ring.push([lambda, phi]);\n ringSink.point(lambda, phi);\n }\n\n function ringStart() {\n ringSink.lineStart();\n ring = [];\n }\n\n function ringEnd() {\n pointRing(ring[0][0], ring[0][1]);\n ringSink.lineEnd();\n\n var clean = ringSink.clean(),\n ringSegments = ringBuffer.result(),\n i, n = ringSegments.length, m,\n segment,\n point;\n\n ring.pop();\n polygon.push(ring);\n ring = null;\n\n if (!n) return;\n\n // No intersections.\n if (clean & 1) {\n segment = ringSegments[0];\n if ((m = segment.length - 1) > 0) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n sink.lineEnd();\n }\n return;\n }\n\n // Rejoin connected segments.\n // TODO reuse ringBuffer.rejoin()?\n if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n segments.push(ringSegments.filter(validSegment));\n }\n\n return clip;\n };\n}\n\nfunction validSegment(segment) {\n return segment.length > 1;\n}\n\n// Intersections are sorted along the clip edge. For both antimeridian cutting\n// and circle clipping, the same comparison is used.\nfunction compareIntersection(a, b) {\n return ((a = a.x)[0] < 0 ? a[1] - halfPi - epsilon : halfPi - a[1])\n - ((b = b.x)[0] < 0 ? b[1] - halfPi - epsilon : halfPi - b[1]);\n}\n","import clip from \"./index\";\nimport {abs, atan, cos, epsilon, halfPi, pi, sin} from \"../math\";\n\nexport default clip(\n function() { return true; },\n clipAntimeridianLine,\n clipAntimeridianInterpolate,\n [-pi, -halfPi]\n);\n\n// Takes a line and cuts into visible segments. Return values: 0 - there were\n// intersections or the line was empty; 1 - no intersections; 2 - there were\n// intersections, and the first and last segments should be rejoined.\nfunction clipAntimeridianLine(stream) {\n var lambda0 = NaN,\n phi0 = NaN,\n sign0 = NaN,\n clean; // no intersections\n\n return {\n lineStart: function() {\n stream.lineStart();\n clean = 1;\n },\n point: function(lambda1, phi1) {\n var sign1 = lambda1 > 0 ? pi : -pi,\n delta = abs(lambda1 - lambda0);\n if (abs(delta - pi) < epsilon) { // line crosses a pole\n stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi : -halfPi);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n stream.point(lambda1, phi0);\n clean = 0;\n } else if (sign0 !== sign1 && delta >= pi) { // line crosses antimeridian\n if (abs(lambda0 - sign0) < epsilon) lambda0 -= sign0 * epsilon; // handle degeneracies\n if (abs(lambda1 - sign1) < epsilon) lambda1 -= sign1 * epsilon;\n phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n clean = 0;\n }\n stream.point(lambda0 = lambda1, phi0 = phi1);\n sign0 = sign1;\n },\n lineEnd: function() {\n stream.lineEnd();\n lambda0 = phi0 = NaN;\n },\n clean: function() {\n return 2 - clean; // if intersections, rejoin first and last segments\n }\n };\n}\n\nfunction clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n var cosPhi0,\n cosPhi1,\n sinLambda0Lambda1 = sin(lambda0 - lambda1);\n return abs(sinLambda0Lambda1) > epsilon\n ? atan((sin(phi0) * (cosPhi1 = cos(phi1)) * sin(lambda1)\n - sin(phi1) * (cosPhi0 = cos(phi0)) * sin(lambda0))\n / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n : (phi0 + phi1) / 2;\n}\n\nfunction clipAntimeridianInterpolate(from, to, direction, stream) {\n var phi;\n if (from == null) {\n phi = direction * halfPi;\n stream.point(-pi, phi);\n stream.point(0, phi);\n stream.point(pi, phi);\n stream.point(pi, 0);\n stream.point(pi, -phi);\n stream.point(0, -phi);\n stream.point(-pi, -phi);\n stream.point(-pi, 0);\n stream.point(-pi, phi);\n } else if (abs(from[0] - to[0]) > epsilon) {\n var lambda = from[0] < to[0] ? pi : -pi;\n phi = direction * lambda / 2;\n stream.point(-lambda, phi);\n stream.point(0, phi);\n stream.point(lambda, phi);\n } else {\n stream.point(to[0], to[1]);\n }\n}\n","import {cartesian, cartesianAddInPlace, cartesianCross, cartesianDot, cartesianScale, spherical} from \"../cartesian\";\nimport {circleStream} from \"../circle\";\nimport {abs, cos, epsilon, pi, radians, sqrt} from \"../math\";\nimport pointEqual from \"../pointEqual\";\nimport clip from \"./index\";\n\nexport default function(radius) {\n var cr = cos(radius),\n delta = 6 * radians,\n smallRadius = cr > 0,\n notHemisphere = abs(cr) > epsilon; // TODO optimise for this common case\n\n function interpolate(from, to, direction, stream) {\n circleStream(stream, radius, delta, direction, from, to);\n }\n\n function visible(lambda, phi) {\n return cos(lambda) * cos(phi) > cr;\n }\n\n // Takes a line and cuts into visible segments. Return values used for polygon\n // clipping: 0 - there were intersections or the line was empty; 1 - no\n // intersections 2 - there were intersections, and the first and last segments\n // should be rejoined.\n function clipLine(stream) {\n var point0, // previous point\n c0, // code for previous point\n v0, // visibility of previous point\n v00, // visibility of first point\n clean; // no intersections\n return {\n lineStart: function() {\n v00 = v0 = false;\n clean = 1;\n },\n point: function(lambda, phi) {\n var point1 = [lambda, phi],\n point2,\n v = visible(lambda, phi),\n c = smallRadius\n ? v ? 0 : code(lambda, phi)\n : v ? code(lambda + (lambda < 0 ? pi : -pi), phi) : 0;\n if (!point0 && (v00 = v0 = v)) stream.lineStart();\n // Handle degeneracies.\n // TODO ignore if not clipping polygons.\n if (v !== v0) {\n point2 = intersect(point0, point1);\n if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2)) {\n point1[0] += epsilon;\n point1[1] += epsilon;\n v = visible(point1[0], point1[1]);\n }\n }\n if (v !== v0) {\n clean = 0;\n if (v) {\n // outside going in\n stream.lineStart();\n point2 = intersect(point1, point0);\n stream.point(point2[0], point2[1]);\n } else {\n // inside going out\n point2 = intersect(point0, point1);\n stream.point(point2[0], point2[1]);\n stream.lineEnd();\n }\n point0 = point2;\n } else if (notHemisphere && point0 && smallRadius ^ v) {\n var t;\n // If the codes for two points are different, or are both zero,\n // and there this segment intersects with the small circle.\n if (!(c & c0) && (t = intersect(point1, point0, true))) {\n clean = 0;\n if (smallRadius) {\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n } else {\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n }\n }\n }\n if (v && (!point0 || !pointEqual(point0, point1))) {\n stream.point(point1[0], point1[1]);\n }\n point0 = point1, v0 = v, c0 = c;\n },\n lineEnd: function() {\n if (v0) stream.lineEnd();\n point0 = null;\n },\n // Rejoin first and last segments if there were intersections and the first\n // and last points were visible.\n clean: function() {\n return clean | ((v00 && v0) << 1);\n }\n };\n }\n\n // Intersects the great circle between a and b with the clip circle.\n function intersect(a, b, two) {\n var pa = cartesian(a),\n pb = cartesian(b);\n\n // We have two planes, n1.p = d1 and n2.p = d2.\n // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n var n1 = [1, 0, 0], // normal\n n2 = cartesianCross(pa, pb),\n n2n2 = cartesianDot(n2, n2),\n n1n2 = n2[0], // cartesianDot(n1, n2),\n determinant = n2n2 - n1n2 * n1n2;\n\n // Two polar points.\n if (!determinant) return !two && a;\n\n var c1 = cr * n2n2 / determinant,\n c2 = -cr * n1n2 / determinant,\n n1xn2 = cartesianCross(n1, n2),\n A = cartesianScale(n1, c1),\n B = cartesianScale(n2, c2);\n cartesianAddInPlace(A, B);\n\n // Solve |p(t)|^2 = 1.\n var u = n1xn2,\n w = cartesianDot(A, u),\n uu = cartesianDot(u, u),\n t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n if (t2 < 0) return;\n\n var t = sqrt(t2),\n q = cartesianScale(u, (-w - t) / uu);\n cartesianAddInPlace(q, A);\n q = spherical(q);\n\n if (!two) return q;\n\n // Two intersection points.\n var lambda0 = a[0],\n lambda1 = b[0],\n phi0 = a[1],\n phi1 = b[1],\n z;\n\n if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n var delta = lambda1 - lambda0,\n polar = abs(delta - pi) < epsilon,\n meridian = polar || delta < epsilon;\n\n if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n // Check that the first point is between a and b.\n if (meridian\n ? polar\n ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon ? phi0 : phi1)\n : phi0 <= q[1] && q[1] <= phi1\n : delta > pi ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n var q1 = cartesianScale(u, (-w + t) / uu);\n cartesianAddInPlace(q1, A);\n return [q, spherical(q1)];\n }\n }\n\n // Generates a 4-bit vector representing the location of a point relative to\n // the small circle's bounding box.\n function code(lambda, phi) {\n var r = smallRadius ? radius : pi - radius,\n code = 0;\n if (lambda < -r) code |= 1; // left\n else if (lambda > r) code |= 2; // right\n if (phi < -r) code |= 4; // below\n else if (phi > r) code |= 8; // above\n return code;\n }\n\n return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi, radius - pi]);\n}\n","export default function(a, b, x0, y0, x1, y1) {\n var ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n return true;\n}\n","import {abs, epsilon} from \"../math\";\nimport clipBuffer from \"./buffer\";\nimport clipLine from \"./line\";\nimport clipRejoin from \"./rejoin\";\nimport {merge} from \"d3-array\";\n\nvar clipMax = 1e9, clipMin = -clipMax;\n\n// TODO Use d3-polygon’s polygonContains here for the ring check?\n// TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\nexport default function clipRectangle(x0, y0, x1, y1) {\n\n function visible(x, y) {\n return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n }\n\n function interpolate(from, to, direction, stream) {\n var a = 0, a1 = 0;\n if (from == null\n || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n || comparePoint(from, to) < 0 ^ direction > 0) {\n do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n while ((a = (a + direction + 4) % 4) !== a1);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function corner(p, direction) {\n return abs(p[0] - x0) < epsilon ? direction > 0 ? 0 : 3\n : abs(p[0] - x1) < epsilon ? direction > 0 ? 2 : 1\n : abs(p[1] - y0) < epsilon ? direction > 0 ? 1 : 0\n : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n }\n\n function compareIntersection(a, b) {\n return comparePoint(a.x, b.x);\n }\n\n function comparePoint(a, b) {\n var ca = corner(a, 1),\n cb = corner(b, 1);\n return ca !== cb ? ca - cb\n : ca === 0 ? b[1] - a[1]\n : ca === 1 ? a[0] - b[0]\n : ca === 2 ? a[1] - b[1]\n : b[0] - a[0];\n }\n\n return function(stream) {\n var activeStream = stream,\n bufferStream = clipBuffer(),\n segments,\n polygon,\n ring,\n x__, y__, v__, // first point\n x_, y_, v_, // previous point\n first,\n clean;\n\n var clipStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: polygonStart,\n polygonEnd: polygonEnd\n };\n\n function point(x, y) {\n if (visible(x, y)) activeStream.point(x, y);\n }\n\n function polygonInside() {\n var winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n }\n }\n\n return winding;\n }\n\n // Buffer geometry within a polygon and then clip it en masse.\n function polygonStart() {\n activeStream = bufferStream, segments = [], polygon = [], clean = true;\n }\n\n function polygonEnd() {\n var startInside = polygonInside(),\n cleanInside = clean && startInside,\n visible = (segments = merge(segments)).length;\n if (cleanInside || visible) {\n stream.polygonStart();\n if (cleanInside) {\n stream.lineStart();\n interpolate(null, null, 1, stream);\n stream.lineEnd();\n }\n if (visible) {\n clipRejoin(segments, compareIntersection, startInside, interpolate, stream);\n }\n stream.polygonEnd();\n }\n activeStream = stream, segments = polygon = ring = null;\n }\n\n function lineStart() {\n clipStream.point = linePoint;\n if (polygon) polygon.push(ring = []);\n first = true;\n v_ = false;\n x_ = y_ = NaN;\n }\n\n // TODO rather than special-case polygons, simply handle them separately.\n // Ideally, coincident intersection points should be jittered to avoid\n // clipping issues.\n function lineEnd() {\n if (segments) {\n linePoint(x__, y__);\n if (v__ && v_) bufferStream.rejoin();\n segments.push(bufferStream.result());\n }\n clipStream.point = point;\n if (v_) activeStream.lineEnd();\n }\n\n function linePoint(x, y) {\n var v = visible(x, y);\n if (polygon) ring.push([x, y]);\n if (first) {\n x__ = x, y__ = y, v__ = v;\n first = false;\n if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n }\n } else {\n if (v && v_) activeStream.point(x, y);\n else {\n var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n if (clipLine(a, b, x0, y0, x1, y1)) {\n if (!v_) {\n activeStream.lineStart();\n activeStream.point(a[0], a[1]);\n }\n activeStream.point(b[0], b[1]);\n if (!v) activeStream.lineEnd();\n clean = false;\n } else if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n clean = false;\n }\n }\n }\n x_ = x, y_ = y, v_ = v;\n }\n\n return clipStream;\n };\n}\n","import clipRectangle from \"./rectangle\";\n\nexport default function() {\n var x0 = 0,\n y0 = 0,\n x1 = 960,\n y1 = 500,\n cache,\n cacheStream,\n clip;\n\n return clip = {\n stream: function(stream) {\n return cache && cacheStream === stream ? cache : cache = clipRectangle(x0, y0, x1, y1)(cacheStream = stream);\n },\n extent: function(_) {\n return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];\n }\n };\n}\n","import adder from \"./adder\";\nimport {abs, atan2, cos, radians, sin, sqrt} from \"./math\";\nimport noop from \"./noop\";\nimport stream from \"./stream\";\n\nvar lengthSum = adder(),\n lambda0,\n sinPhi0,\n cosPhi0;\n\nvar lengthStream = {\n sphere: noop,\n point: noop,\n lineStart: lengthLineStart,\n lineEnd: noop,\n polygonStart: noop,\n polygonEnd: noop\n};\n\nfunction lengthLineStart() {\n lengthStream.point = lengthPointFirst;\n lengthStream.lineEnd = lengthLineEnd;\n}\n\nfunction lengthLineEnd() {\n lengthStream.point = lengthStream.lineEnd = noop;\n}\n\nfunction lengthPointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n lambda0 = lambda, sinPhi0 = sin(phi), cosPhi0 = cos(phi);\n lengthStream.point = lengthPoint;\n}\n\nfunction lengthPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var sinPhi = sin(phi),\n cosPhi = cos(phi),\n delta = abs(lambda - lambda0),\n cosDelta = cos(delta),\n sinDelta = sin(delta),\n x = cosPhi * sinDelta,\n y = cosPhi0 * sinPhi - sinPhi0 * cosPhi * cosDelta,\n z = sinPhi0 * sinPhi + cosPhi0 * cosPhi * cosDelta;\n lengthSum.add(atan2(sqrt(x * x + y * y), z));\n lambda0 = lambda, sinPhi0 = sinPhi, cosPhi0 = cosPhi;\n}\n\nexport default function(object) {\n lengthSum.reset();\n stream(object, lengthStream);\n return +lengthSum;\n}\n","import length from \"./length\";\n\nvar coordinates = [null, null],\n object = {type: \"LineString\", coordinates: coordinates};\n\nexport default function(a, b) {\n coordinates[0] = a;\n coordinates[1] = b;\n return length(object);\n}\n","import {default as polygonContains} from \"./polygonContains\";\nimport {default as distance} from \"./distance\";\nimport {epsilon, radians} from \"./math\";\n\nvar containsObjectType = {\n Feature: function(object, point) {\n return containsGeometry(object.geometry, point);\n },\n FeatureCollection: function(object, point) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) if (containsGeometry(features[i].geometry, point)) return true;\n return false;\n }\n};\n\nvar containsGeometryType = {\n Sphere: function() {\n return true;\n },\n Point: function(object, point) {\n return containsPoint(object.coordinates, point);\n },\n MultiPoint: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsPoint(coordinates[i], point)) return true;\n return false;\n },\n LineString: function(object, point) {\n return containsLine(object.coordinates, point);\n },\n MultiLineString: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsLine(coordinates[i], point)) return true;\n return false;\n },\n Polygon: function(object, point) {\n return containsPolygon(object.coordinates, point);\n },\n MultiPolygon: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsPolygon(coordinates[i], point)) return true;\n return false;\n },\n GeometryCollection: function(object, point) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) if (containsGeometry(geometries[i], point)) return true;\n return false;\n }\n};\n\nfunction containsGeometry(geometry, point) {\n return geometry && containsGeometryType.hasOwnProperty(geometry.type)\n ? containsGeometryType[geometry.type](geometry, point)\n : false;\n}\n\nfunction containsPoint(coordinates, point) {\n return distance(coordinates, point) === 0;\n}\n\nfunction containsLine(coordinates, point) {\n var ab = distance(coordinates[0], coordinates[1]),\n ao = distance(coordinates[0], point),\n ob = distance(point, coordinates[1]);\n return ao + ob <= ab + epsilon;\n}\n\nfunction containsPolygon(coordinates, point) {\n return !!polygonContains(coordinates.map(ringRadians), pointRadians(point));\n}\n\nfunction ringRadians(ring) {\n return ring = ring.map(pointRadians), ring.pop(), ring;\n}\n\nfunction pointRadians(point) {\n return [point[0] * radians, point[1] * radians];\n}\n\nexport default function(object, point) {\n return (object && containsObjectType.hasOwnProperty(object.type)\n ? containsObjectType[object.type]\n : containsGeometry)(object, point);\n}\n","import {range} from \"d3-array\";\nimport {abs, ceil, epsilon} from \"./math\";\n\nfunction graticuleX(y0, y1, dy) {\n var y = range(y0, y1 - epsilon, dy).concat(y1);\n return function(x) { return y.map(function(y) { return [x, y]; }); };\n}\n\nfunction graticuleY(x0, x1, dx) {\n var x = range(x0, x1 - epsilon, dx).concat(x1);\n return function(y) { return x.map(function(x) { return [x, y]; }); };\n}\n\nexport default function graticule() {\n var x1, x0, X1, X0,\n y1, y0, Y1, Y0,\n dx = 10, dy = dx, DX = 90, DY = 360,\n x, y, X, Y,\n precision = 2.5;\n\n function graticule() {\n return {type: \"MultiLineString\", coordinates: lines()};\n }\n\n function lines() {\n return range(ceil(X0 / DX) * DX, X1, DX).map(X)\n .concat(range(ceil(Y0 / DY) * DY, Y1, DY).map(Y))\n .concat(range(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon; }).map(x))\n .concat(range(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon; }).map(y));\n }\n\n graticule.lines = function() {\n return lines().map(function(coordinates) { return {type: \"LineString\", coordinates: coordinates}; });\n };\n\n graticule.outline = function() {\n return {\n type: \"Polygon\",\n coordinates: [\n X(X0).concat(\n Y(Y1).slice(1),\n X(X1).reverse().slice(1),\n Y(Y0).reverse().slice(1))\n ]\n };\n };\n\n graticule.extent = function(_) {\n if (!arguments.length) return graticule.extentMinor();\n return graticule.extentMajor(_).extentMinor(_);\n };\n\n graticule.extentMajor = function(_) {\n if (!arguments.length) return [[X0, Y0], [X1, Y1]];\n X0 = +_[0][0], X1 = +_[1][0];\n Y0 = +_[0][1], Y1 = +_[1][1];\n if (X0 > X1) _ = X0, X0 = X1, X1 = _;\n if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.extentMinor = function(_) {\n if (!arguments.length) return [[x0, y0], [x1, y1]];\n x0 = +_[0][0], x1 = +_[1][0];\n y0 = +_[0][1], y1 = +_[1][1];\n if (x0 > x1) _ = x0, x0 = x1, x1 = _;\n if (y0 > y1) _ = y0, y0 = y1, y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.step = function(_) {\n if (!arguments.length) return graticule.stepMinor();\n return graticule.stepMajor(_).stepMinor(_);\n };\n\n graticule.stepMajor = function(_) {\n if (!arguments.length) return [DX, DY];\n DX = +_[0], DY = +_[1];\n return graticule;\n };\n\n graticule.stepMinor = function(_) {\n if (!arguments.length) return [dx, dy];\n dx = +_[0], dy = +_[1];\n return graticule;\n };\n\n graticule.precision = function(_) {\n if (!arguments.length) return precision;\n precision = +_;\n x = graticuleX(y0, y1, 90);\n y = graticuleY(x0, x1, precision);\n X = graticuleX(Y0, Y1, 90);\n Y = graticuleY(X0, X1, precision);\n return graticule;\n };\n\n return graticule\n .extentMajor([[-180, -90 + epsilon], [180, 90 - epsilon]])\n .extentMinor([[-180, -80 - epsilon], [180, 80 + epsilon]]);\n}\n\nexport function graticule10() {\n return graticule()();\n}\n","import {asin, atan2, cos, degrees, haversin, radians, sin, sqrt} from \"./math\";\n\nexport default function(a, b) {\n var x0 = a[0] * radians,\n y0 = a[1] * radians,\n x1 = b[0] * radians,\n y1 = b[1] * radians,\n cy0 = cos(y0),\n sy0 = sin(y0),\n cy1 = cos(y1),\n sy1 = sin(y1),\n kx0 = cy0 * cos(x0),\n ky0 = cy0 * sin(x0),\n kx1 = cy1 * cos(x1),\n ky1 = cy1 * sin(x1),\n d = 2 * asin(sqrt(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),\n k = sin(d);\n\n var interpolate = d ? function(t) {\n var B = sin(t *= d) / k,\n A = sin(d - t) / k,\n x = A * kx0 + B * kx1,\n y = A * ky0 + B * ky1,\n z = A * sy0 + B * sy1;\n return [\n atan2(y, x) * degrees,\n atan2(z, sqrt(x * x + y * y)) * degrees\n ];\n } : function() {\n return [x0 * degrees, y0 * degrees];\n };\n\n interpolate.distance = d;\n\n return interpolate;\n}\n","import adder from \"../adder\";\nimport {abs} from \"../math\";\nimport noop from \"../noop\";\n\nvar areaSum = adder(),\n areaRingSum = adder(),\n x00,\n y00,\n x0,\n y0;\n\nvar areaStream = {\n point: noop,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: function() {\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n areaStream.lineStart = areaStream.lineEnd = areaStream.point = noop;\n areaSum.add(abs(areaRingSum));\n areaRingSum.reset();\n },\n result: function() {\n var area = areaSum / 2;\n areaSum.reset();\n return area;\n }\n};\n\nfunction areaRingStart() {\n areaStream.point = areaPointFirst;\n}\n\nfunction areaPointFirst(x, y) {\n areaStream.point = areaPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction areaPoint(x, y) {\n areaRingSum.add(y0 * x - x0 * y);\n x0 = x, y0 = y;\n}\n\nfunction areaRingEnd() {\n areaPoint(x00, y00);\n}\n\nexport default areaStream;\n","export default function(x) {\n return x;\n}\n","import noop from \"../noop\";\n\nvar x0 = Infinity,\n y0 = x0,\n x1 = -x0,\n y1 = x1;\n\nvar boundsStream = {\n point: boundsPoint,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: noop,\n polygonEnd: noop,\n result: function() {\n var bounds = [[x0, y0], [x1, y1]];\n x1 = y1 = -(y0 = x0 = Infinity);\n return bounds;\n }\n};\n\nfunction boundsPoint(x, y) {\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n}\n\nexport default boundsStream;\n","import {sqrt} from \"../math\";\n\n// TODO Enforce positive area for exterior, negative area for interior?\n\nvar X0 = 0,\n Y0 = 0,\n Z0 = 0,\n X1 = 0,\n Y1 = 0,\n Z1 = 0,\n X2 = 0,\n Y2 = 0,\n Z2 = 0,\n x00,\n y00,\n x0,\n y0;\n\nvar centroidStream = {\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.point = centroidPoint;\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n },\n result: function() {\n var centroid = Z2 ? [X2 / Z2, Y2 / Z2]\n : Z1 ? [X1 / Z1, Y1 / Z1]\n : Z0 ? [X0 / Z0, Y0 / Z0]\n : [NaN, NaN];\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n return centroid;\n }\n};\n\nfunction centroidPoint(x, y) {\n X0 += x;\n Y0 += y;\n ++Z0;\n}\n\nfunction centroidLineStart() {\n centroidStream.point = centroidPointFirstLine;\n}\n\nfunction centroidPointFirstLine(x, y) {\n centroidStream.point = centroidPointLine;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidPointLine(x, y) {\n var dx = x - x0, dy = y - y0, z = sqrt(dx * dx + dy * dy);\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidLineEnd() {\n centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingStart() {\n centroidStream.point = centroidPointFirstRing;\n}\n\nfunction centroidRingEnd() {\n centroidPointRing(x00, y00);\n}\n\nfunction centroidPointFirstRing(x, y) {\n centroidStream.point = centroidPointRing;\n centroidPoint(x00 = x0 = x, y00 = y0 = y);\n}\n\nfunction centroidPointRing(x, y) {\n var dx = x - x0,\n dy = y - y0,\n z = sqrt(dx * dx + dy * dy);\n\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n\n z = y0 * x - x0 * y;\n X2 += z * (x0 + x);\n Y2 += z * (y0 + y);\n Z2 += z * 3;\n centroidPoint(x0 = x, y0 = y);\n}\n\nexport default centroidStream;\n","import {tau} from \"../math\";\nimport noop from \"../noop\";\n\nexport default function PathContext(context) {\n this._context = context;\n}\n\nPathContext.prototype = {\n _radius: 4.5,\n pointRadius: function(_) {\n return this._radius = _, this;\n },\n polygonStart: function() {\n this._line = 0;\n },\n polygonEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line === 0) this._context.closePath();\n this._point = NaN;\n },\n point: function(x, y) {\n switch (this._point) {\n case 0: {\n this._context.moveTo(x, y);\n this._point = 1;\n break;\n }\n case 1: {\n this._context.lineTo(x, y);\n break;\n }\n default: {\n this._context.moveTo(x + this._radius, y);\n this._context.arc(x, y, this._radius, 0, tau);\n break;\n }\n }\n },\n result: noop\n};\n","import adder from \"../adder\";\nimport {sqrt} from \"../math\";\nimport noop from \"../noop\";\n\nvar lengthSum = adder(),\n lengthRing,\n x00,\n y00,\n x0,\n y0;\n\nvar lengthStream = {\n point: noop,\n lineStart: function() {\n lengthStream.point = lengthPointFirst;\n },\n lineEnd: function() {\n if (lengthRing) lengthPoint(x00, y00);\n lengthStream.point = noop;\n },\n polygonStart: function() {\n lengthRing = true;\n },\n polygonEnd: function() {\n lengthRing = null;\n },\n result: function() {\n var length = +lengthSum;\n lengthSum.reset();\n return length;\n }\n};\n\nfunction lengthPointFirst(x, y) {\n lengthStream.point = lengthPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction lengthPoint(x, y) {\n x0 -= x, y0 -= y;\n lengthSum.add(sqrt(x0 * x0 + y0 * y0));\n x0 = x, y0 = y;\n}\n\nexport default lengthStream;\n","export default function PathString() {\n this._string = [];\n}\n\nPathString.prototype = {\n _radius: 4.5,\n _circle: circle(4.5),\n pointRadius: function(_) {\n if ((_ = +_) !== this._radius) this._radius = _, this._circle = null;\n return this;\n },\n polygonStart: function() {\n this._line = 0;\n },\n polygonEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line === 0) this._string.push(\"Z\");\n this._point = NaN;\n },\n point: function(x, y) {\n switch (this._point) {\n case 0: {\n this._string.push(\"M\", x, \",\", y);\n this._point = 1;\n break;\n }\n case 1: {\n this._string.push(\"L\", x, \",\", y);\n break;\n }\n default: {\n if (this._circle == null) this._circle = circle(this._radius);\n this._string.push(\"M\", x, \",\", y, this._circle);\n break;\n }\n }\n },\n result: function() {\n if (this._string.length) {\n var result = this._string.join(\"\");\n this._string = [];\n return result;\n } else {\n return null;\n }\n }\n};\n\nfunction circle(radius) {\n return \"m0,\" + radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + -2 * radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + 2 * radius\n + \"z\";\n}\n","import identity from \"../identity\";\nimport stream from \"../stream\";\nimport pathArea from \"./area\";\nimport pathBounds from \"./bounds\";\nimport pathCentroid from \"./centroid\";\nimport PathContext from \"./context\";\nimport pathMeasure from \"./measure\";\nimport PathString from \"./string\";\n\nexport default function(projection, context) {\n var pointRadius = 4.5,\n projectionStream,\n contextStream;\n\n function path(object) {\n if (object) {\n if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n stream(object, projectionStream(contextStream));\n }\n return contextStream.result();\n }\n\n path.area = function(object) {\n stream(object, projectionStream(pathArea));\n return pathArea.result();\n };\n\n path.measure = function(object) {\n stream(object, projectionStream(pathMeasure));\n return pathMeasure.result();\n };\n\n path.bounds = function(object) {\n stream(object, projectionStream(pathBounds));\n return pathBounds.result();\n };\n\n path.centroid = function(object) {\n stream(object, projectionStream(pathCentroid));\n return pathCentroid.result();\n };\n\n path.projection = function(_) {\n return arguments.length ? (projectionStream = _ == null ? (projection = null, identity) : (projection = _).stream, path) : projection;\n };\n\n path.context = function(_) {\n if (!arguments.length) return context;\n contextStream = _ == null ? (context = null, new PathString) : new PathContext(context = _);\n if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n return path;\n };\n\n path.pointRadius = function(_) {\n if (!arguments.length) return pointRadius;\n pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n return path;\n };\n\n return path.projection(projection).context(context);\n}\n","export default function(methods) {\n return {\n stream: transformer(methods)\n };\n}\n\nexport function transformer(methods) {\n return function(stream) {\n var s = new TransformStream;\n for (var key in methods) s[key] = methods[key];\n s.stream = stream;\n return s;\n };\n}\n\nfunction TransformStream() {}\n\nTransformStream.prototype = {\n constructor: TransformStream,\n point: function(x, y) { this.stream.point(x, y); },\n sphere: function() { this.stream.sphere(); },\n lineStart: function() { this.stream.lineStart(); },\n lineEnd: function() { this.stream.lineEnd(); },\n polygonStart: function() { this.stream.polygonStart(); },\n polygonEnd: function() { this.stream.polygonEnd(); }\n};\n","import {default as geoStream} from \"../stream\";\nimport boundsStream from \"../path/bounds\";\n\nfunction fit(projection, fitBounds, object) {\n var clip = projection.clipExtent && projection.clipExtent();\n projection.scale(150).translate([0, 0]);\n if (clip != null) projection.clipExtent(null);\n geoStream(object, projection.stream(boundsStream));\n fitBounds(boundsStream.result());\n if (clip != null) projection.clipExtent(clip);\n return projection;\n}\n\nexport function fitExtent(projection, extent, object) {\n return fit(projection, function(b) {\n var w = extent[1][0] - extent[0][0],\n h = extent[1][1] - extent[0][1],\n k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),\n x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,\n y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitSize(projection, size, object) {\n return fitExtent(projection, [[0, 0], size], object);\n}\n\nexport function fitWidth(projection, width, object) {\n return fit(projection, function(b) {\n var w = +width,\n k = w / (b[1][0] - b[0][0]),\n x = (w - k * (b[1][0] + b[0][0])) / 2,\n y = -k * b[0][1];\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitHeight(projection, height, object) {\n return fit(projection, function(b) {\n var h = +height,\n k = h / (b[1][1] - b[0][1]),\n x = -k * b[0][0],\n y = (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n","import {cartesian} from \"../cartesian\";\nimport {abs, asin, atan2, cos, epsilon, radians, sqrt} from \"../math\";\nimport {transformer} from \"../transform\";\n\nvar maxDepth = 16, // maximum depth of subdivision\n cosMinDistance = cos(30 * radians); // cos(minimum angular distance)\n\nexport default function(project, delta2) {\n return +delta2 ? resample(project, delta2) : resampleNone(project);\n}\n\nfunction resampleNone(project) {\n return transformer({\n point: function(x, y) {\n x = project(x, y);\n this.stream.point(x[0], x[1]);\n }\n });\n}\n\nfunction resample(project, delta2) {\n\n function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n var dx = x1 - x0,\n dy = y1 - y0,\n d2 = dx * dx + dy * dy;\n if (d2 > 4 * delta2 && depth--) {\n var a = a0 + a1,\n b = b0 + b1,\n c = c0 + c1,\n m = sqrt(a * a + b * b + c * c),\n phi2 = asin(c /= m),\n lambda2 = abs(abs(c) - 1) < epsilon || abs(lambda0 - lambda1) < epsilon ? (lambda0 + lambda1) / 2 : atan2(b, a),\n p = project(lambda2, phi2),\n x2 = p[0],\n y2 = p[1],\n dx2 = x2 - x0,\n dy2 = y2 - y0,\n dz = dy * dx2 - dx * dy2;\n if (dz * dz / d2 > delta2 // perpendicular projected distance\n || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n stream.point(x2, y2);\n resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n }\n }\n }\n return function(stream) {\n var lambda00, x00, y00, a00, b00, c00, // first point\n lambda0, x0, y0, a0, b0, c0; // previous point\n\n var resampleStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n };\n\n function point(x, y) {\n x = project(x, y);\n stream.point(x[0], x[1]);\n }\n\n function lineStart() {\n x0 = NaN;\n resampleStream.point = linePoint;\n stream.lineStart();\n }\n\n function linePoint(lambda, phi) {\n var c = cartesian([lambda, phi]), p = project(lambda, phi);\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n stream.point(x0, y0);\n }\n\n function lineEnd() {\n resampleStream.point = point;\n stream.lineEnd();\n }\n\n function ringStart() {\n lineStart();\n resampleStream.point = ringPoint;\n resampleStream.lineEnd = ringEnd;\n }\n\n function ringPoint(lambda, phi) {\n linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n resampleStream.point = linePoint;\n }\n\n function ringEnd() {\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n resampleStream.lineEnd = lineEnd;\n lineEnd();\n }\n\n return resampleStream;\n };\n}\n","import clipAntimeridian from \"../clip/antimeridian\";\nimport clipCircle from \"../clip/circle\";\nimport clipRectangle from \"../clip/rectangle\";\nimport compose from \"../compose\";\nimport identity from \"../identity\";\nimport {cos, degrees, radians, sin, sqrt} from \"../math\";\nimport {rotateRadians} from \"../rotation\";\nimport {transformer} from \"../transform\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit\";\nimport resample from \"./resample\";\n\nvar transformRadians = transformer({\n point: function(x, y) {\n this.stream.point(x * radians, y * radians);\n }\n});\n\nfunction transformRotate(rotate) {\n return transformer({\n point: function(x, y) {\n var r = rotate(x, y);\n return this.stream.point(r[0], r[1]);\n }\n });\n}\n\nfunction scaleTranslate(k, dx, dy) {\n function transform(x, y) {\n return [dx + k * x, dy - k * y];\n }\n transform.invert = function(x, y) {\n return [(x - dx) / k, (dy - y) / k];\n };\n return transform;\n}\n\nfunction scaleTranslateRotate(k, dx, dy, alpha) {\n var cosAlpha = cos(alpha),\n sinAlpha = sin(alpha),\n a = cosAlpha * k,\n b = sinAlpha * k,\n ai = cosAlpha / k,\n bi = sinAlpha / k,\n ci = (sinAlpha * dy - cosAlpha * dx) / k,\n fi = (sinAlpha * dx + cosAlpha * dy) / k;\n function transform(x, y) {\n return [a * x - b * y + dx, dy - b * x - a * y];\n }\n transform.invert = function(x, y) {\n return [ai * x - bi * y + ci, fi - bi * x - ai * y];\n };\n return transform;\n}\n\nexport default function projection(project) {\n return projectionMutator(function() { return project; })();\n}\n\nexport function projectionMutator(projectAt) {\n var project,\n k = 150, // scale\n x = 480, y = 250, // translate\n lambda = 0, phi = 0, // center\n deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, // pre-rotate\n alpha = 0, // post-rotate\n theta = null, preclip = clipAntimeridian, // pre-clip angle\n x0 = null, y0, x1, y1, postclip = identity, // post-clip extent\n delta2 = 0.5, // precision\n projectResample,\n projectTransform,\n projectRotateTransform,\n cache,\n cacheStream;\n\n function projection(point) {\n return projectRotateTransform(point[0] * radians, point[1] * radians);\n }\n\n function invert(point) {\n point = projectRotateTransform.invert(point[0], point[1]);\n return point && [point[0] * degrees, point[1] * degrees];\n }\n\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transformRadians(transformRotate(rotate)(preclip(projectResample(postclip(cacheStream = stream)))));\n };\n\n projection.preclip = function(_) {\n return arguments.length ? (preclip = _, theta = undefined, reset()) : preclip;\n };\n\n projection.postclip = function(_) {\n return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;\n };\n\n projection.clipAngle = function(_) {\n return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees;\n };\n\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n projection.scale = function(_) {\n return arguments.length ? (k = +_, recenter()) : k;\n };\n\n projection.translate = function(_) {\n return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n };\n\n projection.center = function(_) {\n return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees, phi * degrees];\n };\n\n projection.rotate = function(_) {\n return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees, deltaPhi * degrees, deltaGamma * degrees];\n };\n\n projection.angle = function(_) {\n return arguments.length ? (alpha = _ % 360 * radians, recenter()) : alpha * degrees;\n };\n\n projection.precision = function(_) {\n return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt(delta2);\n };\n\n projection.fitExtent = function(extent, object) {\n return fitExtent(projection, extent, object);\n };\n\n projection.fitSize = function(size, object) {\n return fitSize(projection, size, object);\n };\n\n projection.fitWidth = function(width, object) {\n return fitWidth(projection, width, object);\n };\n\n projection.fitHeight = function(height, object) {\n return fitHeight(projection, height, object);\n };\n\n function recenter() {\n var center = scaleTranslateRotate(k, 0, 0, alpha).apply(null, project(lambda, phi)),\n transform = (alpha ? scaleTranslateRotate : scaleTranslate)(k, x - center[0], y - center[1], alpha);\n rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma);\n projectTransform = compose(project, transform);\n projectRotateTransform = compose(rotate, projectTransform);\n projectResample = resample(projectTransform, delta2);\n return reset();\n }\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return function() {\n project = projectAt.apply(this, arguments);\n projection.invert = project.invert && invert;\n return recenter();\n };\n}\n","import {degrees, pi, radians} from \"../math\";\nimport {projectionMutator} from \"./index\";\n\nexport function conicProjection(projectAt) {\n var phi0 = 0,\n phi1 = pi / 3,\n m = projectionMutator(projectAt),\n p = m(phi0, phi1);\n\n p.parallels = function(_) {\n return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees, phi1 * degrees];\n };\n\n return p;\n}\n","import {asin, cos, sin} from \"../math\";\n\nexport function cylindricalEqualAreaRaw(phi0) {\n var cosPhi0 = cos(phi0);\n\n function forward(lambda, phi) {\n return [lambda * cosPhi0, sin(phi) / cosPhi0];\n }\n\n forward.invert = function(x, y) {\n return [x / cosPhi0, asin(y * cosPhi0)];\n };\n\n return forward;\n}\n","import {abs, asin, atan2, cos, epsilon, sign, sin, sqrt} from \"../math\";\nimport {conicProjection} from \"./conic\";\nimport {cylindricalEqualAreaRaw} from \"./cylindricalEqualArea\";\n\nexport function conicEqualAreaRaw(y0, y1) {\n var sy0 = sin(y0), n = (sy0 + sin(y1)) / 2;\n\n // Are the parallels symmetrical around the Equator?\n if (abs(n) < epsilon) return cylindricalEqualAreaRaw(y0);\n\n var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt(c) / n;\n\n function project(x, y) {\n var r = sqrt(c - 2 * n * sin(y)) / n;\n return [r * sin(x *= n), r0 - r * cos(x)];\n }\n\n project.invert = function(x, y) {\n var r0y = r0 - y;\n return [atan2(x, abs(r0y)) / n * sign(r0y), asin((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEqualAreaRaw)\n .scale(155.424)\n .center([0, 33.6442]);\n}\n","import conicEqualArea from \"./conicEqualArea\";\n\nexport default function() {\n return conicEqualArea()\n .parallels([29.5, 45.5])\n .scale(1070)\n .translate([480, 250])\n .rotate([96, 0])\n .center([-0.6, 38.7]);\n}\n","import {epsilon} from \"../math\";\nimport albers from \"./albers\";\nimport conicEqualArea from \"./conicEqualArea\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit\";\n\n// The projections must have mutually exclusive clip regions on the sphere,\n// as this will avoid emitting interleaving lines and polygons.\nfunction multiplex(streams) {\n var n = streams.length;\n return {\n point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n };\n}\n\n// A composite projection for the United States, configured by default for\n// 960×500. The projection also works quite well at 960×600 if you change the\n// scale to 1285 and adjust the translate accordingly. The set of standard\n// parallels for each region comes from USGS, which is published here:\n// http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\nexport default function() {\n var cache,\n cacheStream,\n lower48 = albers(), lower48Point,\n alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n function albersUsa(coordinates) {\n var x = coordinates[0], y = coordinates[1];\n return point = null,\n (lower48Point.point(x, y), point)\n || (alaskaPoint.point(x, y), point)\n || (hawaiiPoint.point(x, y), point);\n }\n\n albersUsa.invert = function(coordinates) {\n var k = lower48.scale(),\n t = lower48.translate(),\n x = (coordinates[0] - t[0]) / k,\n y = (coordinates[1] - t[1]) / k;\n return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n : lower48).invert(coordinates);\n };\n\n albersUsa.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n };\n\n albersUsa.precision = function(_) {\n if (!arguments.length) return lower48.precision();\n lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n return reset();\n };\n\n albersUsa.scale = function(_) {\n if (!arguments.length) return lower48.scale();\n lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n return albersUsa.translate(lower48.translate());\n };\n\n albersUsa.translate = function(_) {\n if (!arguments.length) return lower48.translate();\n var k = lower48.scale(), x = +_[0], y = +_[1];\n\n lower48Point = lower48\n .translate(_)\n .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n .stream(pointStream);\n\n alaskaPoint = alaska\n .translate([x - 0.307 * k, y + 0.201 * k])\n .clipExtent([[x - 0.425 * k + epsilon, y + 0.120 * k + epsilon], [x - 0.214 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n hawaiiPoint = hawaii\n .translate([x - 0.205 * k, y + 0.212 * k])\n .clipExtent([[x - 0.214 * k + epsilon, y + 0.166 * k + epsilon], [x - 0.115 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n return reset();\n };\n\n albersUsa.fitExtent = function(extent, object) {\n return fitExtent(albersUsa, extent, object);\n };\n\n albersUsa.fitSize = function(size, object) {\n return fitSize(albersUsa, size, object);\n };\n\n albersUsa.fitWidth = function(width, object) {\n return fitWidth(albersUsa, width, object);\n };\n\n albersUsa.fitHeight = function(height, object) {\n return fitHeight(albersUsa, height, object);\n };\n\n function reset() {\n cache = cacheStream = null;\n return albersUsa;\n }\n\n return albersUsa.scale(1070);\n}\n","import {asin, atan2, cos, sin, sqrt} from \"../math\";\n\nexport function azimuthalRaw(scale) {\n return function(x, y) {\n var cx = cos(x),\n cy = cos(y),\n k = scale(cx * cy);\n return [\n k * cy * sin(x),\n k * sin(y)\n ];\n }\n}\n\nexport function azimuthalInvert(angle) {\n return function(x, y) {\n var z = sqrt(x * x + y * y),\n c = angle(z),\n sc = sin(c),\n cc = cos(c);\n return [\n atan2(x * sc, z * cc),\n asin(z && y * sc / z)\n ];\n }\n}\n","import {asin, sqrt} from \"../math\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal\";\nimport projection from \"./index\";\n\nexport var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n return sqrt(2 / (1 + cxcy));\n});\n\nazimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n return 2 * asin(z / 2);\n});\n\nexport default function() {\n return projection(azimuthalEqualAreaRaw)\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n}\n","import {acos, sin} from \"../math\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal\";\nimport projection from \"./index\";\n\nexport var azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n return (c = acos(c)) && c / sin(c);\n});\n\nazimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n return z;\n});\n\nexport default function() {\n return projection(azimuthalEquidistantRaw)\n .scale(79.4188)\n .clipAngle(180 - 1e-3);\n}\n","import {atan, exp, halfPi, log, pi, tan, tau} from \"../math\";\nimport rotation from \"../rotation\";\nimport projection from \"./index\";\n\nexport function mercatorRaw(lambda, phi) {\n return [lambda, log(tan((halfPi + phi) / 2))];\n}\n\nmercatorRaw.invert = function(x, y) {\n return [x, 2 * atan(exp(y)) - halfPi];\n};\n\nexport default function() {\n return mercatorProjection(mercatorRaw)\n .scale(961 / tau);\n}\n\nexport function mercatorProjection(project) {\n var m = projection(project),\n center = m.center,\n scale = m.scale,\n translate = m.translate,\n clipExtent = m.clipExtent,\n x0 = null, y0, x1, y1; // clip extent\n\n m.scale = function(_) {\n return arguments.length ? (scale(_), reclip()) : scale();\n };\n\n m.translate = function(_) {\n return arguments.length ? (translate(_), reclip()) : translate();\n };\n\n m.center = function(_) {\n return arguments.length ? (center(_), reclip()) : center();\n };\n\n m.clipExtent = function(_) {\n return arguments.length ? ((_ == null ? x0 = y0 = x1 = y1 = null : (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1])), reclip()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n function reclip() {\n var k = pi * scale(),\n t = m(rotation(m.rotate()).invert([0, 0]));\n return clipExtent(x0 == null\n ? [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]] : project === mercatorRaw\n ? [[Math.max(t[0] - k, x0), y0], [Math.min(t[0] + k, x1), y1]]\n : [[x0, Math.max(t[1] - k, y0)], [x1, Math.min(t[1] + k, y1)]]);\n }\n\n return reclip();\n}\n","import {abs, atan, atan2, cos, epsilon, halfPi, log, pow, sign, sin, sqrt, tan} from \"../math\";\nimport {conicProjection} from \"./conic\";\nimport {mercatorRaw} from \"./mercator\";\n\nfunction tany(y) {\n return tan((halfPi + y) / 2);\n}\n\nexport function conicConformalRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : log(cy0 / cos(y1)) / log(tany(y1) / tany(y0)),\n f = cy0 * pow(tany(y0), n) / n;\n\n if (!n) return mercatorRaw;\n\n function project(x, y) {\n if (f > 0) { if (y < -halfPi + epsilon) y = -halfPi + epsilon; }\n else { if (y > halfPi - epsilon) y = halfPi - epsilon; }\n var r = f / pow(tany(y), n);\n return [r * sin(n * x), f - r * cos(n * x)];\n }\n\n project.invert = function(x, y) {\n var fy = f - y, r = sign(n) * sqrt(x * x + fy * fy);\n return [atan2(x, abs(fy)) / n * sign(fy), 2 * atan(pow(f / r, 1 / n)) - halfPi];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicConformalRaw)\n .scale(109.5)\n .parallels([30, 30]);\n}\n","import projection from \"./index\";\n\nexport function equirectangularRaw(lambda, phi) {\n return [lambda, phi];\n}\n\nequirectangularRaw.invert = equirectangularRaw;\n\nexport default function() {\n return projection(equirectangularRaw)\n .scale(152.63);\n}\n","import {abs, atan2, cos, epsilon, sign, sin, sqrt} from \"../math\";\nimport {conicProjection} from \"./conic\";\nimport {equirectangularRaw} from \"./equirectangular\";\n\nexport function conicEquidistantRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : (cy0 - cos(y1)) / (y1 - y0),\n g = cy0 / n + y0;\n\n if (abs(n) < epsilon) return equirectangularRaw;\n\n function project(x, y) {\n var gy = g - y, nx = n * x;\n return [gy * sin(nx), g - gy * cos(nx)];\n }\n\n project.invert = function(x, y) {\n var gy = g - y;\n return [atan2(x, abs(gy)) / n * sign(gy), g - sign(n) * sqrt(x * x + gy * gy)];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEquidistantRaw)\n .scale(131.154)\n .center([0, 13.9389]);\n}\n","import projection from \"./index.js\";\nimport {abs, asin, cos, epsilon2, sin, sqrt} from \"../math.js\";\n\nvar A1 = 1.340264,\n A2 = -0.081106,\n A3 = 0.000893,\n A4 = 0.003796,\n M = sqrt(3) / 2,\n iterations = 12;\n\nexport function equalEarthRaw(lambda, phi) {\n var l = asin(M * sin(phi)), l2 = l * l, l6 = l2 * l2 * l2;\n return [\n lambda * cos(l) / (M * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2))),\n l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2))\n ];\n}\n\nequalEarthRaw.invert = function(x, y) {\n var l = y, l2 = l * l, l6 = l2 * l2 * l2;\n for (var i = 0, delta, fy, fpy; i < iterations; ++i) {\n fy = l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2)) - y;\n fpy = A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2);\n l -= delta = fy / fpy, l2 = l * l, l6 = l2 * l2 * l2;\n if (abs(delta) < epsilon2) break;\n }\n return [\n M * x * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2)) / cos(l),\n asin(sin(l) / M)\n ];\n};\n\nexport default function() {\n return projection(equalEarthRaw)\n .scale(177.158);\n}\n","import {atan, cos, sin} from \"../math\";\nimport {azimuthalInvert} from \"./azimuthal\";\nimport projection from \"./index\";\n\nexport function gnomonicRaw(x, y) {\n var cy = cos(y), k = cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\ngnomonicRaw.invert = azimuthalInvert(atan);\n\nexport default function() {\n return projection(gnomonicRaw)\n .scale(144.049)\n .clipAngle(60);\n}\n","import clipRectangle from \"../clip/rectangle\";\nimport identity from \"../identity\";\nimport {transformer} from \"../transform\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit\";\n\nfunction scaleTranslate(kx, ky, tx, ty) {\n return kx === 1 && ky === 1 && tx === 0 && ty === 0 ? identity : transformer({\n point: function(x, y) {\n this.stream.point(x * kx + tx, y * ky + ty);\n }\n });\n}\n\nexport default function() {\n var k = 1, tx = 0, ty = 0, sx = 1, sy = 1, transform = identity, // scale, translate and reflect\n x0 = null, y0, x1, y1, // clip extent\n postclip = identity,\n cache,\n cacheStream,\n projection;\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return projection = {\n stream: function(stream) {\n return cache && cacheStream === stream ? cache : cache = transform(postclip(cacheStream = stream));\n },\n postclip: function(_) {\n return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;\n },\n clipExtent: function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n },\n scale: function(_) {\n return arguments.length ? (transform = scaleTranslate((k = +_) * sx, k * sy, tx, ty), reset()) : k;\n },\n translate: function(_) {\n return arguments.length ? (transform = scaleTranslate(k * sx, k * sy, tx = +_[0], ty = +_[1]), reset()) : [tx, ty];\n },\n reflectX: function(_) {\n return arguments.length ? (transform = scaleTranslate(k * (sx = _ ? -1 : 1), k * sy, tx, ty), reset()) : sx < 0;\n },\n reflectY: function(_) {\n return arguments.length ? (transform = scaleTranslate(k * sx, k * (sy = _ ? -1 : 1), tx, ty), reset()) : sy < 0;\n },\n fitExtent: function(extent, object) {\n return fitExtent(projection, extent, object);\n },\n fitSize: function(size, object) {\n return fitSize(projection, size, object);\n },\n fitWidth: function(width, object) {\n return fitWidth(projection, width, object);\n },\n fitHeight: function(height, object) {\n return fitHeight(projection, height, object);\n }\n };\n}\n","import projection from \"./index\";\nimport {abs, epsilon} from \"../math\";\n\nexport function naturalEarth1Raw(lambda, phi) {\n var phi2 = phi * phi, phi4 = phi2 * phi2;\n return [\n lambda * (0.8707 - 0.131979 * phi2 + phi4 * (-0.013791 + phi4 * (0.003971 * phi2 - 0.001529 * phi4))),\n phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4)))\n ];\n}\n\nnaturalEarth1Raw.invert = function(x, y) {\n var phi = y, i = 25, delta;\n do {\n var phi2 = phi * phi, phi4 = phi2 * phi2;\n phi -= delta = (phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4))) - y) /\n (1.007226 + phi2 * (0.015085 * 3 + phi4 * (-0.044475 * 7 + 0.028874 * 9 * phi2 - 0.005916 * 11 * phi4)));\n } while (abs(delta) > epsilon && --i > 0);\n return [\n x / (0.8707 + (phi2 = phi * phi) * (-0.131979 + phi2 * (-0.013791 + phi2 * phi2 * phi2 * (0.003971 - 0.001529 * phi2)))),\n phi\n ];\n};\n\nexport default function() {\n return projection(naturalEarth1Raw)\n .scale(175.295);\n}\n","import {asin, cos, epsilon, sin} from \"../math\";\nimport {azimuthalInvert} from \"./azimuthal\";\nimport projection from \"./index\";\n\nexport function orthographicRaw(x, y) {\n return [cos(y) * sin(x), sin(y)];\n}\n\northographicRaw.invert = azimuthalInvert(asin);\n\nexport default function() {\n return projection(orthographicRaw)\n .scale(249.5)\n .clipAngle(90 + epsilon);\n}\n","import {atan, cos, sin} from \"../math\";\nimport {azimuthalInvert} from \"./azimuthal\";\nimport projection from \"./index\";\n\nexport function stereographicRaw(x, y) {\n var cy = cos(y), k = 1 + cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\nstereographicRaw.invert = azimuthalInvert(function(z) {\n return 2 * atan(z);\n});\n\nexport default function() {\n return projection(stereographicRaw)\n .scale(250)\n .clipAngle(142);\n}\n","import {atan, exp, halfPi, log, tan} from \"../math\";\nimport {mercatorProjection} from \"./mercator\";\n\nexport function transverseMercatorRaw(lambda, phi) {\n return [log(tan((halfPi + phi) / 2)), -lambda];\n}\n\ntransverseMercatorRaw.invert = function(x, y) {\n return [-y, 2 * atan(exp(x)) - halfPi];\n};\n\nexport default function() {\n var m = mercatorProjection(transverseMercatorRaw),\n center = m.center,\n rotate = m.rotate;\n\n m.center = function(_) {\n return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n };\n\n m.rotate = function(_) {\n return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n };\n\n return rotate([0, 0, 90])\n .scale(159.155);\n}\n","export {default as geoArea} from \"./area\";\nexport {default as geoBounds} from \"./bounds\";\nexport {default as geoCentroid} from \"./centroid\";\nexport {default as geoCircle} from \"./circle\";\nexport {default as geoClipAntimeridian} from \"./clip/antimeridian\";\nexport {default as geoClipCircle} from \"./clip/circle\";\nexport {default as geoClipExtent} from \"./clip/extent\"; // DEPRECATED! Use d3.geoIdentity().clipExtent(…).\nexport {default as geoClipRectangle} from \"./clip/rectangle\";\nexport {default as geoContains} from \"./contains\";\nexport {default as geoDistance} from \"./distance\";\nexport {default as geoGraticule, graticule10 as geoGraticule10} from \"./graticule\";\nexport {default as geoInterpolate} from \"./interpolate\";\nexport {default as geoLength} from \"./length\";\nexport {default as geoPath} from \"./path/index\";\nexport {default as geoAlbers} from \"./projection/albers\";\nexport {default as geoAlbersUsa} from \"./projection/albersUsa\";\nexport {default as geoAzimuthalEqualArea, azimuthalEqualAreaRaw as geoAzimuthalEqualAreaRaw} from \"./projection/azimuthalEqualArea\";\nexport {default as geoAzimuthalEquidistant, azimuthalEquidistantRaw as geoAzimuthalEquidistantRaw} from \"./projection/azimuthalEquidistant\";\nexport {default as geoConicConformal, conicConformalRaw as geoConicConformalRaw} from \"./projection/conicConformal\";\nexport {default as geoConicEqualArea, conicEqualAreaRaw as geoConicEqualAreaRaw} from \"./projection/conicEqualArea\";\nexport {default as geoConicEquidistant, conicEquidistantRaw as geoConicEquidistantRaw} from \"./projection/conicEquidistant\";\nexport {default as geoEqualEarth, equalEarthRaw as geoEqualEarthRaw} from \"./projection/equalEarth\";\nexport {default as geoEquirectangular, equirectangularRaw as geoEquirectangularRaw} from \"./projection/equirectangular\";\nexport {default as geoGnomonic, gnomonicRaw as geoGnomonicRaw} from \"./projection/gnomonic\";\nexport {default as geoIdentity} from \"./projection/identity\";\nexport {default as geoProjection, projectionMutator as geoProjectionMutator} from \"./projection/index\";\nexport {default as geoMercator, mercatorRaw as geoMercatorRaw} from \"./projection/mercator\";\nexport {default as geoNaturalEarth1, naturalEarth1Raw as geoNaturalEarth1Raw} from \"./projection/naturalEarth1\";\nexport {default as geoOrthographic, orthographicRaw as geoOrthographicRaw} from \"./projection/orthographic\";\nexport {default as geoStereographic, stereographicRaw as geoStereographicRaw} from \"./projection/stereographic\";\nexport {default as geoTransverseMercator, transverseMercatorRaw as geoTransverseMercatorRaw} from \"./projection/transverseMercator\";\nexport {default as geoRotation} from \"./rotation\";\nexport {default as geoStream} from \"./stream\";\nexport {default as geoTransform} from \"./transform\";\n","\"use strict\"\n\nmodule.exports = linearExpansionSum\n\n//Easy case: Add two scalars\nfunction scalarScalar(a, b) {\n var x = a + b\n var bv = x - a\n var av = x - bv\n var br = b - bv\n var ar = a - av\n var y = ar + br\n if(y) {\n return [y, x]\n }\n return [x]\n}\n\nfunction linearExpansionSum(e, f) {\n var ne = e.length|0\n var nf = f.length|0\n if(ne === 1 && nf === 1) {\n return scalarScalar(e[0], f[0])\n }\n var n = ne + nf\n var g = new Array(n)\n var count = 0\n var eptr = 0\n var fptr = 0\n var abs = Math.abs\n var ei = e[eptr]\n var ea = abs(ei)\n var fi = f[fptr]\n var fa = abs(fi)\n var a, b\n if(ea < fa) {\n b = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n b = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n if((eptr < ne && ea < fa) || (fptr >= nf)) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n var x = a + b\n var bv = x - a\n var y = b - bv\n var q0 = y\n var q1 = x\n var _x, _bv, _av, _br, _ar\n while(eptr < ne && fptr < nf) {\n if(ea < fa) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n }\n while(eptr < ne) {\n a = ei\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n }\n }\n while(fptr < nf) {\n a = fi\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n } \n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n }\n }\n if(q0) {\n g[count++] = q0\n }\n if(q1) {\n g[count++] = q1\n }\n if(!count) {\n g[count++] = 0.0 \n }\n g.length = count\n return g\n}","/**\n * Bit twiddling hacks for JavaScript.\n *\n * Author: Mikola Lysenko\n *\n * Ported from Stanford bit twiddling hack library:\n * http://graphics.stanford.edu/~seander/bithacks.html\n */\n\n\"use strict\"; \"use restrict\";\n\n//Number of bits in an integer\nvar INT_BITS = 32;\n\n//Constants\nexports.INT_BITS = INT_BITS;\nexports.INT_MAX = 0x7fffffff;\nexports.INT_MIN = -1<<(INT_BITS-1);\n\n//Returns -1, 0, +1 depending on sign of x\nexports.sign = function(v) {\n return (v > 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n var mask = v >> (INT_BITS-1);\n return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n var r, shift;\n r = (v > 0xFFFF) << 4; v >>>= r;\n shift = (v > 0xFF ) << 3; v >>>= shift; r |= shift;\n shift = (v > 0xF ) << 2; v >>>= shift; r |= shift;\n shift = (v > 0x3 ) << 1; v >>>= shift; r |= shift;\n return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n return (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n var c = 32;\n v &= -v;\n if (v) c--;\n if (v & 0x0000FFFF) c -= 16;\n if (v & 0x00FF00FF) c -= 8;\n if (v & 0x0F0F0F0F) c -= 4;\n if (v & 0x33333333) c -= 2;\n if (v & 0x55555555) c -= 1;\n return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n v += v === 0;\n --v;\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n v ^= v >>> 16;\n v ^= v >>> 8;\n v ^= v >>> 4;\n v &= 0xf;\n return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n for(var i=0; i<256; ++i) {\n var v = i, r = i, s = 7;\n for (v >>>= 1; v; v >>>= 1) {\n r <<= 1;\n r |= v & 1;\n --s;\n }\n tab[i] = (r << s) & 0xff;\n }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n return (REVERSE_TABLE[ v & 0xff] << 24) |\n (REVERSE_TABLE[(v >>> 8) & 0xff] << 16) |\n (REVERSE_TABLE[(v >>> 16) & 0xff] << 8) |\n REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits. Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n x &= 0xFFFF;\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y &= 0xFFFF;\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n v = (v >>> n) & 0x55555555;\n v = (v | (v >>> 1)) & 0x33333333;\n v = (v | (v >>> 2)) & 0x0F0F0F0F;\n v = (v | (v >>> 4)) & 0x00FF00FF;\n v = (v | (v >>> 16)) & 0x000FFFF;\n return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits. Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n x &= 0x3FF;\n x = (x | (x<<16)) & 4278190335;\n x = (x | (x<<8)) & 251719695;\n x = (x | (x<<4)) & 3272356035;\n x = (x | (x<<2)) & 1227133513;\n\n y &= 0x3FF;\n y = (y | (y<<16)) & 4278190335;\n y = (y | (y<<8)) & 251719695;\n y = (y | (y<<4)) & 3272356035;\n y = (y | (y<<2)) & 1227133513;\n x |= (y << 1);\n \n z &= 0x3FF;\n z = (z | (z<<16)) & 4278190335;\n z = (z | (z<<8)) & 251719695;\n z = (z | (z<<4)) & 3272356035;\n z = (z | (z<<2)) & 1227133513;\n \n return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n v = (v >>> n) & 1227133513;\n v = (v | (v>>>2)) & 3272356035;\n v = (v | (v>>>4)) & 251719695;\n v = (v | (v>>>8)) & 4278190335;\n v = (v | (v>>>16)) & 0x3FF;\n return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n var t = v | (v - 1);\n return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n","var point = require('@turf/helpers').point;\n\n/**\n * Takes a {@link LineString|linestring}, {@link MultiLineString|multi-linestring}, {@link MultiPolygon|multi-polygon}, or {@link Polygon|polygon} and returns {@link Point|points} at all self-intersections.\n *\n * @name kinks\n * @param {Feature} featureIn input feature\n * @returns {FeatureCollection} self-intersections\n * @example\n * var poly = turf.polygon([[\n * [-12.034835, 8.901183],\n * [-12.060413, 8.899826],\n * [-12.03638, 8.873199],\n * [-12.059383, 8.871418],\n * [-12.034835, 8.901183]\n * ]]);\n *\n * var kinks = turf.kinks(poly);\n *\n * //addToMap\n * var addToMap = [poly, kinks]\n */\nmodule.exports = function (featureIn) {\n var coordinates;\n var feature;\n var results = {\n type: 'FeatureCollection',\n features: []\n };\n if (featureIn.type === 'Feature') {\n feature = featureIn.geometry;\n } else {\n feature = featureIn;\n }\n if (feature.type === 'LineString') {\n coordinates = [feature.coordinates];\n } else if (feature.type === 'MultiLineString') {\n coordinates = feature.coordinates;\n } else if (feature.type === 'MultiPolygon') {\n coordinates = [].concat.apply([], feature.coordinates);\n } else if (feature.type === 'Polygon') {\n coordinates = feature.coordinates;\n } else {\n throw new Error('Input must be a LineString, MultiLineString, ' +\n 'Polygon, or MultiPolygon Feature or Geometry');\n }\n coordinates.forEach(function (line1) {\n coordinates.forEach(function (line2) {\n for (var i = 0; i < line1.length - 1; i++) {\n // start iteration at i, intersections for k < i have already been checked in previous outer loop iterations\n for (var k = i; k < line2.length - 1; k++) {\n if (line1 === line2) {\n // segments are adjacent and always share a vertex, not a kink\n if (Math.abs(i - k) === 1) {\n continue;\n }\n // first and last segment in a closed lineString or ring always share a vertex, not a kink\n if (\n // segments are first and last segment of lineString\n i === 0 &&\n k === line1.length - 2 &&\n // lineString is closed\n line1[i][0] === line1[line1.length - 1][0] &&\n line1[i][1] === line1[line1.length - 1][1]\n ) {\n continue;\n }\n }\n\n var intersection = lineIntersects(line1[i][0], line1[i][1], line1[i + 1][0], line1[i + 1][1],\n line2[k][0], line2[k][1], line2[k + 1][0], line2[k + 1][1]);\n if (intersection) {\n results.features.push(point([intersection[0], intersection[1]]));\n }\n }\n }\n });\n });\n return results;\n};\n\n\n// modified from http://jsfiddle.net/justin_c_rounds/Gd2S2/light/\nfunction lineIntersects(line1StartX, line1StartY, line1EndX, line1EndY, line2StartX, line2StartY, line2EndX, line2EndY) {\n // if the lines intersect, the result contains the x and y of the intersection (treating the lines as infinite) and booleans for whether line segment 1 or line segment 2 contain the point\n var denominator, a, b, numerator1, numerator2,\n result = {\n x: null,\n y: null,\n onLine1: false,\n onLine2: false\n };\n denominator = ((line2EndY - line2StartY) * (line1EndX - line1StartX)) - ((line2EndX - line2StartX) * (line1EndY - line1StartY));\n if (denominator === 0) {\n if (result.x !== null && result.y !== null) {\n return result;\n } else {\n return false;\n }\n }\n a = line1StartY - line2StartY;\n b = line1StartX - line2StartX;\n numerator1 = ((line2EndX - line2StartX) * a) - ((line2EndY - line2StartY) * b);\n numerator2 = ((line1EndX - line1StartX) * a) - ((line1EndY - line1StartY) * b);\n a = numerator1 / denominator;\n b = numerator2 / denominator;\n\n // if we cast these lines infinitely in both directions, they intersect here:\n result.x = line1StartX + (a * (line1EndX - line1StartX));\n result.y = line1StartY + (a * (line1EndY - line1StartY));\n\n // if line1 is a segment and line2 is infinite, they intersect if:\n if (a >= 0 && a <= 1) {\n result.onLine1 = true;\n }\n // if line2 is a segment and line1 is infinite, they intersect if:\n if (b >= 0 && b <= 1) {\n result.onLine2 = true;\n }\n // if line1 and line2 are segments, they intersect if both of the above are true\n if (result.onLine1 && result.onLine2) {\n return [result.x, result.y];\n } else {\n return false;\n }\n}\n","var turfbbox = require('@turf/bbox');\nvar inside = require('@turf/inside');\nvar rbush = require('rbush');\n\n/**\n * Merges a specified property from a FeatureCollection of points into a\n * FeatureCollection of polygons. Given an `inProperty` on points and an `outProperty`\n * for polygons, this finds every point that lies within each polygon, collects the\n * `inProperty` values from those points, and adds them as an array to `outProperty`\n * on the polygon.\n *\n * @name collect\n * @param {FeatureCollection} polygons polygons with values on which to aggregate\n * @param {FeatureCollection} points points to be aggregated\n * @param {string} inProperty property to be nested from\n * @param {string} outProperty property to be nested into\n * @returns {FeatureCollection} polygons with properties listed based on `outField`\n * @example\n * var poly1 = turf.polygon([[[0,0],[10,0],[10,10],[0,10],[0,0]]]);\n * var poly2 = turf.polygon([[[10,0],[20,10],[20,20],[20,0],[10,0]]]);\n * var polyFC = turf.featureCollection([poly1, poly2]);\n * var pt1 = turf.point([5,5], {population: 200});\n * var pt2 = turf.point([1,3], {population: 600});\n * var pt3 = turf.point([14,2], {population: 100});\n * var pt4 = turf.point([13,1], {population: 200});\n * var pt5 = turf.point([19,7], {population: 300});\n * var pointFC = turf.featureCollection([pt1, pt2, pt3, pt4, pt5]);\n * var collected = turf.collect(polyFC, pointFC, 'population', 'values');\n * var values = collected.features[0].properties.values\n * //=values => [200, 600]\n *\n * //addToMap\n * var addToMap = [pointFC, collected]\n */\nmodule.exports = function (polygons, points, inProperty, outProperty) {\n var rtree = rbush(6);\n\n var treeItems = points.features.map(function (item) {\n return {\n minX: item.geometry.coordinates[0],\n minY: item.geometry.coordinates[1],\n maxX: item.geometry.coordinates[0],\n maxY: item.geometry.coordinates[1],\n property: item.properties[inProperty]\n };\n });\n\n rtree.load(treeItems);\n polygons.features.forEach(function (poly) {\n\n if (!poly.properties) {\n poly.properties = {};\n }\n var bbox = turfbbox(poly);\n var potentialPoints = rtree.search({minX: bbox[0], minY: bbox[1], maxX: bbox[2], maxY: bbox[3]});\n var values = [];\n potentialPoints.forEach(function (pt) {\n if (inside({'type': 'Point', 'coordinates': [pt.minX, pt.minY]}, poly)) {\n values.push(pt.property);\n }\n });\n\n poly.properties[outProperty] = values;\n });\n\n return polygons;\n};\n","// depend on jsts for now https://github.com/bjornharrtell/jsts/blob/master/examples/overlay.html\nvar jsts = require('jsts');\nvar area = require('@turf/area');\nvar feature = require('@turf/helpers').feature;\nvar getGeom = require('@turf/invariant').getGeom;\nvar flattenEach = require('@turf/meta').flattenEach;\n\n/**\n * Finds the difference between two {@link Polygon|polygons} by clipping the second polygon from the first.\n *\n * @name difference\n * @param {Feature} polygon1 input Polygon feature\n * @param {Feature} polygon2 Polygon feature to difference from polygon1\n * @returns {Feature|null} a Polygon or MultiPolygon feature showing the area of `polygon1` excluding the area of `polygon2` (if empty returns `null`)\n * @example\n * var polygon1 = turf.polygon([[\n * [128, -26],\n * [141, -26],\n * [141, -21],\n * [128, -21],\n * [128, -26]\n * ]], {\n * \"fill\": \"#F00\",\n * \"fill-opacity\": 0.1\n * });\n * var polygon2 = turf.polygon([[\n * [126, -28],\n * [140, -28],\n * [140, -20],\n * [126, -20],\n * [126, -28]\n * ]], {\n * \"fill\": \"#00F\",\n * \"fill-opacity\": 0.1\n * });\n *\n * var difference = turf.difference(polygon1, polygon2);\n *\n * //addToMap\n * var addToMap = [polygon1, polygon2, difference];\n */\nmodule.exports = function (polygon1, polygon2) {\n var geom1 = getGeom(polygon1);\n var geom2 = getGeom(polygon2);\n var properties = polygon1.properties || {};\n\n // Issue #721 - JSTS can't handle empty polygons\n geom1 = removeEmptyPolygon(geom1);\n geom2 = removeEmptyPolygon(geom2);\n if (!geom1) return null;\n if (!geom2) return feature(geom1, properties);\n\n // JSTS difference operation\n var reader = new jsts.io.GeoJSONReader();\n var a = reader.read(geom1);\n var b = reader.read(geom2);\n var differenced = a.difference(b);\n if (differenced.isEmpty()) return null;\n var writer = new jsts.io.GeoJSONWriter();\n var geom = writer.write(differenced);\n\n return feature(geom, properties);\n};\n\n/**\n * Detect Empty Polygon\n *\n * @private\n * @param {Geometry} geom Geometry Object\n * @returns {Geometry|null} removed any polygons with no areas\n */\nfunction removeEmptyPolygon(geom) {\n switch (geom.type) {\n case 'Polygon':\n if (area(geom) > 1) return geom;\n return null;\n case 'MultiPolygon':\n var coordinates = [];\n flattenEach(geom, function (feature) {\n if (area(feature) > 1) coordinates.push(feature.geometry.coordinates);\n });\n if (coordinates.length) return {type: 'MultiPolygon', coordinates: coordinates};\n }\n}\n","// Find self-intersections in geojson polygon (possibly with interior rings)\nvar rbush = require('rbush');\n\n\nvar merge = function(){\n var output = {};\n Array.prototype.slice.call(arguments).forEach(function(arg){\n if(arg){\n Object.keys(arg).forEach(function(key){\n output[key]=arg[key];\n });\n }\n });\n return output;\n};\ndefaults = {\n useSpatialIndex: true,\n epsilon: 0,\n reportVertexOnVertex: false,\n reportVertexOnEdge: false\n};\n\nmodule.exports = function(feature, filterFn, options0) {\n var options;\n if(\"object\" === typeof options0){\n options = merge(defaults,options0);\n } else {\n options = merge(defaults,{useSpatialIndex:options0});\n }\n\n if (feature.geometry.type != \"Polygon\") throw new Error(\"The input feature must be a Polygon\");\n\n var coord = feature.geometry.coordinates;\n\n var output = [];\n var seen = {};\n\n if (options.useSpatialIndex) {\n var allEdgesAsRbushTreeItems = [];\n for (var ring0 = 0; ring0 < coord.length; ring0++) {\n for (var edge0 = 0; edge0 < coord[ring0].length-1; edge0++) {\n allEdgesAsRbushTreeItems.push(rbushTreeItem(ring0, edge0))\n }\n }\n var tree = rbush();\n tree.load(allEdgesAsRbushTreeItems);\n }\n\n for (var ring0 = 0; ring0 < coord.length; ring0++) {\n for (var edge0 = 0; edge0 < coord[ring0].length-1; edge0++) {\n if (options.useSpatialIndex) {\n var bboxOverlaps = tree.search(rbushTreeItem(ring0, edge0));\n bboxOverlaps.forEach(function(bboxIsect) {\n var ring1 = bboxIsect.ring;\n var edge1 = bboxIsect.edge;\n ifIsectAddToOutput(ring0, edge0, ring1, edge1);\n });\n }\n else {\n for (var ring1 = 0; ring1 < coord.length; ring1++) {\n for (var edge1 = 0 ; edge1 < coord[ring1].length-1; edge1++) {\n // TODO: speedup possible if only interested in unique: start last two loops at ring0 and edge0+1\n ifIsectAddToOutput(ring0, edge0, ring1, edge1);\n }\n }\n }\n }\n }\n\n if (!filterFn) output = {type: \"Feature\", geometry: {type: \"MultiPoint\", coordinates: output}};\n return output;\n\n // true if frac is (almost) 1.0 or 0.0\n function isBoundaryCase(frac){\n var e2 = options.epsilon * options.epsilon;\n return e2 >= (frac-1)*(frac-1) || e2 >= frac*frac;\n }\n function isOutside(frac){\n return frac < 0 - options.epsilon || frac > 1 + options.epsilon;\n }\n // Function to check if two edges intersect and add the intersection to the output\n function ifIsectAddToOutput(ring0, edge0, ring1, edge1) {\n var start0 = coord[ring0][edge0];\n var end0 = coord[ring0][edge0+1];\n var start1 = coord[ring1][edge1];\n var end1 = coord[ring1][edge1+1];\n\n var isect = intersect(start0, end0, start1, end1);\n\n if (isect == null) return; // discard parallels and coincidence\n frac0, frac1;\n if (end0[0] != start0[0]) {\n var frac0 = (isect[0]-start0[0])/(end0[0]-start0[0]);\n } else {\n var frac0 = (isect[1]-start0[1])/(end0[1]-start0[1]);\n };\n if (end1[0] != start1[0]) {\n var frac1 = (isect[0]-start1[0])/(end1[0]-start1[0]);\n } else {\n var frac1 = (isect[1]-start1[1])/(end1[1]-start1[1]);\n };\n\n // There are roughly three cases we need to deal with.\n // 1. If at least one of the fracs lies outside [0,1], there is no intersection.\n if (isOutside(frac0) || isOutside(frac1)) {\n return; // require segment intersection\n }\n\n // 2. If both are either exactly 0 or exactly 1, this is not an intersection but just\n // two edge segments sharing a common vertex.\n if (isBoundaryCase(frac0) && isBoundaryCase(frac1)){\n if(! options.reportVertexOnVertex) return;\n }\n\n // 3. If only one of the fractions is exactly 0 or 1, this is\n // a vertex-on-edge situation.\n if (isBoundaryCase(frac0) || isBoundaryCase(frac1)){\n if(! options.reportVertexOnEdge) return;\n }\n\n var key = isect;\n var unique = !seen[key];\n if (unique) {\n seen[key] = true;\n }\n\n if (filterFn) {\n output.push(filterFn(isect, ring0, edge0, start0, end0, frac0, ring1, edge1, start1, end1, frac1, unique));\n } else {\n output.push(isect);\n }\n }\n\n // Function to return a rbush tree item given an ring and edge number\n function rbushTreeItem(ring, edge) {\n\n var start = coord[ring][edge];\n var end = coord[ring][edge+1];\n\n if (start[0] < end[0]) {\n var minX = start[0], maxX = end[0];\n } else {\n var minX = end[0], maxX = start[0];\n };\n if (start[1] < end[1]) {\n var minY = start[1], maxY = end[1];\n } else {\n var minY = end[1], maxY = start[1];\n }\n return {minX: minX, minY: minY, maxX: maxX, maxY: maxY, ring: ring, edge: edge};\n }\n\n}\n\n// Function to compute where two lines (not segments) intersect. From https://en.wikipedia.org/wiki/Line%E2%80%93line_intersection\nfunction intersect(start0, end0, start1, end1) {\n if (equalArrays(start0,start1) || equalArrays(start0,end1) || equalArrays(end0,start1) || equalArrays(end1,start1)) return null;\n var x0 = start0[0],\n y0 = start0[1],\n x1 = end0[0],\n y1 = end0[1],\n x2 = start1[0],\n y2 = start1[1],\n x3 = end1[0],\n y3 = end1[1];\n var denom = (x0 - x1) * (y2 - y3) - (y0 - y1) * (x2 - x3);\n if (denom == 0) return null;\n var x4 = ((x0 * y1 - y0 * x1) * (x2 - x3) - (x0 - x1) * (x2 * y3 - y2 * x3)) / denom;\n var y4 = ((x0 * y1 - y0 * x1) * (y2 - y3) - (y0 - y1) * (x2 * y3 - y2 * x3)) / denom;\n return [x4, y4];\n}\n\n// Function to compare Arrays of numbers. From http://stackoverflow.com/questions/7837456/how-to-compare-arrays-in-javascript\nfunction equalArrays(array1, array2) {\n // if the other array is a falsy value, return\n if (!array1 || !array2)\n return false;\n\n // compare lengths - can save a lot of time\n if (array1.length != array2.length)\n return false;\n\n for (var i = 0, l=array1.length; i < l; i++) {\n // Check if we have nested arrays\n if (array1[i] instanceof Array && array2[i] instanceof Array) {\n // recurse into the nested arrays\n if (!equalArrays(array1[i],array2[i]))\n return false;\n }\n else if (array1[i] != array2[i]) {\n // Warning - two different object instances will never be equal: {x:20} != {x:20}\n return false;\n }\n }\n return true;\n}\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FilterSelector.vue?vue&type=style&index=0&id=cd193c48&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FilterSelector.vue?vue&type=style&index=0&id=cd193c48&lang=scss&scoped=true&\"","var getCoord = require('@turf/invariant').getCoord;\n//http://en.wikipedia.org/wiki/Haversine_formula\n//http://www.movable-type.co.uk/scripts/latlong.html\n\n/**\n * Takes two {@link Point|points} and finds the geographic bearing between them,\n * i.e. the angle measured in degrees from the north line (0 degrees)\n *\n * @name bearing\n * @param {Geometry|Feature|Array} start starting Point\n * @param {Geometry|Feature|Array} end ending Point\n * @param {boolean} [final=false] calculates the final bearing if true\n * @returns {number} bearing in decimal degrees, between -180 and 180 degrees (positive clockwise)\n * @example\n * var point1 = turf.point([-75.343, 39.984]);\n * var point2 = turf.point([-75.534, 39.123]);\n *\n * var bearing = turf.bearing(point1, point2);\n *\n * //addToMap\n * var addToMap = [point1, point2]\n * point1.properties['marker-color'] = '#f00'\n * point2.properties['marker-color'] = '#0f0'\n * point1.properties.bearing = bearing\n */\nfunction bearing(start, end, final) {\n if (final === true) return calculateFinalBearing(start, end);\n\n var degrees2radians = Math.PI / 180;\n var radians2degrees = 180 / Math.PI;\n var coordinates1 = getCoord(start);\n var coordinates2 = getCoord(end);\n\n var lon1 = degrees2radians * coordinates1[0];\n var lon2 = degrees2radians * coordinates2[0];\n var lat1 = degrees2radians * coordinates1[1];\n var lat2 = degrees2radians * coordinates2[1];\n var a = Math.sin(lon2 - lon1) * Math.cos(lat2);\n var b = Math.cos(lat1) * Math.sin(lat2) -\n Math.sin(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1);\n\n var bear = radians2degrees * Math.atan2(a, b);\n\n return bear;\n}\n\n/**\n * Calculates Final Bearing\n * @private\n * @param {Feature} start starting Point\n * @param {Feature} end ending Point\n * @returns {number} bearing\n */\nfunction calculateFinalBearing(start, end) {\n // Swap start & end\n var bear = bearing(end, start);\n bear = (bear + 180) % 360;\n return bear;\n}\n\nmodule.exports = bearing;\n","var rbush = require('rbush');\nvar union = require('@turf/union');\nvar helpers = require('@turf/helpers');\nvar turfBBox = require('@turf/bbox');\nvar flattenEach = require('@turf/meta').flattenEach;\n\n/**\n * Takes any type of {@link Polygon|polygon} and an optional mask and returns a {@link Polygon|polygon} exterior ring with holes.\n *\n * @name mask\n * @param {FeatureCollection|Feature} polygon GeoJSON Polygon used as interior rings or holes.\n * @param {Feature} [mask] GeoJSON Polygon used as the exterior ring (if undefined, the world extent is used)\n * @returns {Feature} Masked Polygon (exterior ring with holes).\n * @example\n * var polygon = turf.polygon([[[112, -21], [116, -36], [146, -39], [153, -24], [133, -10], [112, -21]]]);\n * var mask = turf.polygon([[[90, -55], [170, -55], [170, 10], [90, 10], [90, -55]]]);\n *\n * var masked = turf.mask(polygon, mask);\n *\n * //addToMap\n * var addToMap = [masked]\n */\nmodule.exports = function (polygon, mask) {\n // Define mask\n var maskPolygon = createMask(mask);\n\n // Define polygon\n var separated = separatePolygons(polygon);\n var polygonOuters = separated[0];\n var polygonInners = separated[1];\n\n // Union Outers & Inners\n polygonOuters = unionPolygons(polygonOuters);\n polygonInners = unionPolygons(polygonInners);\n\n // Create masked area\n var masked = buildMask(maskPolygon, polygonOuters, polygonInners);\n return masked;\n};\n\n/**\n * Build Mask\n *\n * @private\n * @param {Feature} maskPolygon Mask Outer\n * @param {FeatureCollection} polygonOuters Polygon Outers\n * @param {FeatureCollection} polygonInners Polygon Inners\n * @returns {Feature} Feature Polygon\n */\nfunction buildMask(maskPolygon, polygonOuters, polygonInners) {\n var coordinates = [];\n coordinates.push(maskPolygon.geometry.coordinates[0]);\n\n flattenEach(polygonOuters, function (feature) {\n coordinates.push(feature.geometry.coordinates[0]);\n });\n\n flattenEach(polygonInners, function (feature) {\n coordinates.push(feature.geometry.coordinates[0]);\n });\n return helpers.polygon(coordinates);\n}\n\n/**\n * Separate Polygons to inners & outers\n *\n * @private\n * @param {FeatureCollection|Feature} polygon GeoJSON Feature\n * @returns {Array, FeatureCollection>} Outer & Inner lines\n */\nfunction separatePolygons(polygon) {\n var outers = [];\n var inners = [];\n flattenEach(polygon, function (feature) {\n var coordinates = feature.geometry.coordinates;\n var featureOuter = coordinates[0];\n var featureInner = coordinates.slice(1);\n outers.push(helpers.polygon([featureOuter]));\n featureInner.forEach(function (inner) {\n inners.push(helpers.polygon([inner]));\n });\n });\n return [helpers.featureCollection(outers), helpers.featureCollection(inners)];\n}\n\n/**\n * Create Mask Coordinates\n *\n * @private\n * @param {Feature} [mask] default to world if undefined\n * @returns {Feature} mask coordinate\n */\nfunction createMask(mask) {\n var world = [[[180, 90], [-180, 90], [-180, -90], [180, -90], [180, 90]]];\n var coordinates = mask && mask.geometry.coordinates || world;\n return helpers.polygon(coordinates);\n}\n\n/**\n * Union Polygons\n *\n * @private\n * @param {FeatureCollection} polygons collection of polygons\n * @returns {FeatureCollection} polygons only apply union if they collide\n */\nfunction unionPolygons(polygons) {\n if (polygons.features.length <= 1) return polygons;\n\n var tree = createIndex(polygons);\n var results = [];\n var removed = {};\n\n flattenEach(polygons, function (currentFeature, currentIndex) {\n // Exclude any removed features\n if (removed[currentIndex]) return true;\n\n // Don't search for itself\n tree.remove({index: currentIndex}, filterByIndex);\n removed[currentIndex] = true;\n\n // Keep applying the union operation until no more overlapping features\n while (true) {\n var bbox = turfBBox(currentFeature);\n var search = tree.search({\n minX: bbox[0],\n minY: bbox[1],\n maxX: bbox[2],\n maxY: bbox[3]\n });\n if (search.length > 0) {\n var polys = search.map(function (item) {\n removed[item.index] = true;\n tree.remove({index: item.index}, filterByIndex);\n return item.geojson;\n });\n polys.push(currentFeature);\n currentFeature = union.apply(this, polys);\n }\n // Done\n if (search.length === 0) break;\n }\n results.push(currentFeature);\n });\n\n return helpers.featureCollection(results);\n}\n\n/**\n * Filter by Index - RBush helper function\n *\n * @private\n * @param {Object} a remove item\n * @param {Object} b search item\n * @returns {boolean} true if matches\n */\nfunction filterByIndex(a, b) {\n return a.index === b.index;\n}\n\n/**\n * Create RBush Tree Index\n *\n * @private\n * @param {FeatureCollection} features GeoJSON FeatureCollection\n * @returns {RBush} RBush Tree\n */\nfunction createIndex(features) {\n var tree = rbush();\n var load = [];\n flattenEach(features, function (feature, index) {\n var bbox = turfBBox(feature);\n load.push({\n minX: bbox[0],\n minY: bbox[1],\n maxX: bbox[2],\n maxY: bbox[3],\n geojson: feature,\n index: index\n });\n });\n tree.load(load);\n return tree;\n}\n","export default {\r\n mounted () {\r\n this.$store.commit('fieldRecordSystem/map/setDefaultInteractionsEnabled', false)\r\n },\r\n beforeDestroy () {\r\n this.$store.commit('fieldRecordSystem/map/setDefaultInteractionsEnabled', true)\r\n }\r\n}\r\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Vector-based spherical geodetic (latitude/longitude) functions (c) Chris Veness 2011-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong-vectors.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-latlon-nvector-spherical.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var Vector3d = require('./vector3d.js'); // ≡ import Vector3d from 'vector3d.js'\nif (typeof module!='undefined' && module.exports) var Dms = require('./dms.js'); // ≡ import Dms from 'dms.js'\n\n\n/**\n * Tools for working with points and paths on (a spherical model of) the earth’s surface using a\n * vector-based approach using ‘n-vectors’ (rather than the more common spherical trigonometry;\n * a vector-based approach makes many calculations much simpler, and easier to follow, compared\n * with trigonometric equivalents).\n *\n * Note on a spherical model earth, an n-vector is equivalent to a normalised version of an (ECEF)\n * cartesian coordinate.\n *\n * @module latlon-vectors\n * @requires vector3d\n * @requires dms\n */\n\n\n/**\n * Creates a LatLon point on spherical model earth.\n *\n * @constructor\n * @param {number} lat - Latitude in degrees.\n * @param {number} lon - Longitude in degrees.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n */\nfunction LatLon(lat, lon) {\n // allow instantiation without 'new'\n if (!(this instanceof LatLon)) return new LatLon(lat, lon);\n\n this.lat = Number(lat);\n this.lon = Number(lon);\n}\n\n\n/**\n * Converts ‘this’ lat/lon point to Vector3d n-vector (normal to earth's surface).\n *\n * @returns {Vector3d} Normalised n-vector representing lat/lon point.\n *\n * @example\n * var p = new LatLon(45, 45);\n * var v = p.toVector(); // [0.5000,0.5000,0.7071]\n */\nLatLon.prototype.toVector = function() {\n var φ = this.lat.toRadians();\n var λ = this.lon.toRadians();\n\n // right-handed vector: x -> 0°E,0°N; y -> 90°E,0°N, z -> 90°N\n var x = Math.cos(φ) * Math.cos(λ);\n var y = Math.cos(φ) * Math.sin(λ);\n var z = Math.sin(φ);\n\n return new Vector3d(x, y, z);\n};\n\n\n/**\n * Converts ‘this’ (geocentric) cartesian vector to (spherical) latitude/longitude point.\n *\n * @returns {LatLon} Latitude/longitude point vector points to.\n *\n * @example\n * var v = new Vector3d(0.500, 0.500, 0.707);\n * var p = v.toLatLonS(); // 45.0°N, 45.0°E\n */\nVector3d.prototype.toLatLonS = function() {\n var φ = Math.atan2(this.z, Math.sqrt(this.x*this.x + this.y*this.y));\n var λ = Math.atan2(this.y, this.x);\n\n return new LatLon(φ.toDegrees(), λ.toDegrees());\n};\n\n\n/**\n * N-vector normal to great circle obtained by heading on given bearing from ‘this’ point.\n *\n * Direction of vector is such that initial bearing vector b = c × p.\n *\n * @param {number} bearing - Compass bearing in degrees.\n * @returns {Vector3d} Normalised vector representing great circle.\n *\n * @example\n * var p1 = new LatLon(53.3206, -1.7297);\n * var gc = p1.greatCircle(96.0); // [-0.794,0.129,0.594]\n */\nLatLon.prototype.greatCircle = function(bearing) {\n var φ = this.lat.toRadians();\n var λ = this.lon.toRadians();\n var θ = Number(bearing).toRadians();\n\n var x = Math.sin(λ) * Math.cos(θ) - Math.sin(φ) * Math.cos(λ) * Math.sin(θ);\n var y = -Math.cos(λ) * Math.cos(θ) - Math.sin(φ) * Math.sin(λ) * Math.sin(θ);\n var z = Math.cos(φ) * Math.sin(θ);\n\n return new Vector3d(x, y, z);\n};\n\n\n/**\n * N-vector normal to great circle obtained by heading on given bearing from point given by ‘this’\n * n-vector.\n *\n * Direction of vector is such that initial bearing vector b = c × p.\n *\n * @param {number} bearing - Compass bearing in degrees.\n * @returns {Vector3d} Normalised vector representing great circle.\n *\n * @example\n * var n1 = new LatLon(53.3206, -1.7297).toNvector();\n * var gc = n1.greatCircle(96.0); // [-0.794,0.129,0.594]\n */\nVector3d.prototype.greatCircle = function(bearing) {\n var θ = Number(bearing).toRadians();\n\n var N = new Vector3d(0, 0, 1);\n var e = N.cross(this); // easting\n var n = this.cross(e); // northing\n var eʹ = e.times(Math.cos(θ)/e.length());\n var nʹ = n.times(Math.sin(θ)/n.length());\n var c = nʹ.minus(eʹ);\n\n return c;\n};\n\n\n/**\n * Returns the distance from ‘this’ point to the specified point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance between this point and destination point, in same units as radius.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var d = p1.distanceTo(p2); // 404.3 km\n */\nLatLon.prototype.distanceTo = function(point, radius) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n var p1 = this.toVector();\n var p2 = point.toVector();\n\n var δ = p1.angleTo(p2); // δ = atan2(|p₁×p₂|, p₁·p₂)\n var d = δ * radius;\n\n return d;\n};\n\n\n/**\n * Returns the (initial) bearing from ‘this’ point to the specified point, in compass degrees.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} Initial bearing in degrees from North (0°..360°).\n * @throws {TypeError} Point is not LatLon object.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var b1 = p1.bearingTo(p2); // 156.2°\n */\nLatLon.prototype.bearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n var p1 = this.toVector();\n var p2 = point.toVector();\n\n var N = new Vector3d(0, 0, 1); // n-vector representing north pole\n\n var c1 = p1.cross(p2); // great circle through p1 & p2\n var c2 = p1.cross(N); // great circle through p1 & north pole\n\n var θ = c1.angleTo(c2, p1); // bearing is (signed) angle between c1 & c2\n\n return (θ.toDegrees()+360) % 360; // normalise to 0..360\n};\n\n\n/**\n * Returns the midpoint between ‘this’ point and specified point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {LatLon} Midpoint between this point and destination point.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var pMid = p1.midpointTo(p2); // 50.5363°N, 001.2746°E\n */\nLatLon.prototype.midpointTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n var p1 = this.toVector();\n var p2 = point.toVector();\n\n var mid = p1.plus(p2).unit();\n\n return mid.toLatLonS();\n};\n\n\n/**\n * Returns the point at given fraction between ‘this’ point and specified point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} fraction - Fraction between the two points (0 = this point, 1 = specified point).\n * @returns {LatLon} Intermediate point between this point and destination point.\n * @throws {TypeError} Point is not LatLon object.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var pInt = p1.intermediatePointTo(p2, 0.25); // 51.3721°N, 000.7073°E\n */\nLatLon.prototype.intermediatePointTo = function(point, fraction) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // angular distance between points; tanδ = |n₁×n₂| / n₁⋅n₂\n var n1 = this.toVector();\n var n2 = point.toVector();\n var sinθ = n1.cross(n2).length();\n var cosθ = n1.dot(n2);\n var δ = Math.atan2(sinθ, cosθ);\n\n // interpolated angular distance on straight line between points\n var δi = δ * Number(fraction);\n var sinδi = Math.sin(δi);\n var cosδi = Math.cos(δi);\n\n // direction vector (perpendicular to n1 in plane of n2)\n var d = n1.cross(n2).unit().cross(n1); // unit(n₁×n₂) × n₁\n\n // interpolated position\n var int = n1.times(cosδi).plus(d.times(sinδi)); // n₁⋅cosδᵢ + d⋅sinδᵢ\n\n return new Vector3d(int.x, int.y, int.z).toLatLonS();\n};\n\n\n/**\n * Returns the latitude/longitude point projected from the point at given fraction on a straight\n * line between between ‘this’ point and specified point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} fraction - Fraction between the two points (0 = this point, 1 = specified point).\n * @returns {LatLon} Intermediate point between this point and destination point.\n * @throws {TypeError} Point is not LatLon object.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var pInt = p1.intermediatePointOnChordTo(p2, 0.25); // 51.3723°N, 000.7072°E\n */\nLatLon.prototype.intermediatePointOnChordTo = function(point, fraction) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n var n1 = this.toVector();\n var n2 = point.toVector();\n\n var int = n1.plus(n2.minus(n1).times(Number(fraction))); // n₁ + (n₂−n₁)·f ≡ n₁·(1-f) + n₂·f\n\n return new Vector3d(int.x, int.y, int.z).toLatLonS();\n};\n\n\n/**\n * Returns the destination point from ‘this’ point having travelled the given distance on the\n * given initial bearing (bearing will normally vary before destination is reached).\n *\n * @param {number} distance - Distance travelled, in same units as earth radius (default: metres).\n * @param {number} bearing - Initial bearing in degrees from north.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {LatLon} Destination point.\n *\n * @example\n * var p1 = new LatLon(51.4778, -0.0015);\n * var p2 = p1.destinationPoint(7794, 300.7); // 51.5135°N, 000.0983°W\n */\nLatLon.prototype.destinationPoint = function(distance, bearing, radius) {\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n var n1 = this.toVector();\n var δ = Number(distance) / radius; // angular distance in radians\n var θ = Number(bearing).toRadians();\n\n var N = new Vector3d(0, 0, 1); // north pole\n\n var de = N.cross(n1).unit(); // east direction vector @ n1\n var dn = n1.cross(de); // north direction vector @ n1\n\n var deSinθ = de.times(Math.sin(θ));\n var dnCosθ = dn.times(Math.cos(θ));\n\n var d = dnCosθ.plus(deSinθ); // direction vector @ n1 (≡ C×n1; C = great circle)\n\n var x = n1.times(Math.cos(δ)); // component of n2 parallel to n1\n var y = d.times(Math.sin(δ)); // component of n2 perpendicular to n1\n\n var n2 = x.plus(y);\n\n return n2.toLatLonS();\n};\n\n\n/**\n * Returns the point of intersection of two paths each defined by point pairs or start point and bearing.\n *\n * @param {LatLon} path1start - Start point of first path.\n * @param {LatLon|number} path1brngEnd - End point of first path or initial bearing from first start point.\n * @param {LatLon} path2start - Start point of second path.\n * @param {LatLon|number} path2brngEnd - End point of second path or initial bearing from second start point.\n * @returns {LatLon} Destination point (null if no unique intersection defined)\n *\n * @example\n * var p1 = LatLon(51.8853, 0.2545), brng1 = 108.55;\n * var p2 = LatLon(49.0034, 2.5735), brng2 = 32.44;\n * var pInt = LatLon.intersection(p1, brng1, p2, brng2); // 50.9076°N, 004.5086°E\n */\nLatLon.intersection = function(path1start, path1brngEnd, path2start, path2brngEnd) {\n if (!(path1start instanceof LatLon)) throw new TypeError('path1start is not LatLon object');\n if (!(path2start instanceof LatLon)) throw new TypeError('path2start is not LatLon object');\n if (!(path1brngEnd instanceof LatLon) && isNaN(path1brngEnd)) throw new TypeError('path1brngEnd is not LatLon object or bearing');\n if (!(path2brngEnd instanceof LatLon) && isNaN(path2brngEnd)) throw new TypeError('path2brngEnd is not LatLon object or bearing');\n\n // if c1 & c2 are great circles through start and end points (or defined by start point + bearing),\n // then candidate intersections are simply c1 × c2 & c2 × c1; most of the work is deciding correct\n // intersection point to select! if bearing is given, that determines which intersection, if both\n // paths are defined by start/end points, take closer intersection\n\n var p1 = path1start.toVector();\n var p2 = path2start.toVector();\n\n var c1, c2, path1def, path2def;\n // c1 & c2 are vectors defining great circles through start & end points; p × c gives initial bearing vector\n\n if (path1brngEnd instanceof LatLon) { // path 1 defined by endpoint\n c1 = p1.cross(path1brngEnd.toVector());\n path1def = 'endpoint';\n } else { // path 1 defined by initial bearing\n c1 = path1start.greatCircle(Number(path1brngEnd));\n path1def = 'bearing';\n }\n if (path2brngEnd instanceof LatLon) { // path 2 defined by endpoint\n c2 = p2.cross(path2brngEnd.toVector());\n path2def = 'endpoint';\n } else { // path 2 defined by initial bearing\n c2 = path2start.greatCircle(Number(path2brngEnd));\n path2def = 'bearing';\n }\n\n // there are two (antipodal) candidate intersection points; we have to choose which to return\n var i1 = c1.cross(c2);\n var i2 = c2.cross(c1);\n\n // am I making heavy weather of this? is there a simpler way to do it?\n\n // selection of intersection point depends on how paths are defined (bearings or endpoints)\n var intersection=null, dir1=null, dir2=null;\n switch (path1def+'+'+path2def) {\n case 'bearing+bearing':\n // if c×p⋅i1 is +ve, the initial bearing is towards i1, otherwise towards antipodal i2\n dir1 = Math.sign(c1.cross(p1).dot(i1)); // c1×p1⋅i1 +ve means p1 bearing points to i1\n dir2 = Math.sign(c2.cross(p2).dot(i1)); // c2×p2⋅i1 +ve means p2 bearing points to i1\n\n switch (dir1+dir2) {\n case 2: // dir1, dir2 both +ve, 1 & 2 both pointing to i1\n intersection = i1;\n break;\n case -2: // dir1, dir2 both -ve, 1 & 2 both pointing to i2\n intersection = i2;\n break;\n case 0: // dir1, dir2 opposite; intersection is at further-away intersection point\n // take opposite intersection from mid-point of p1 & p2 [is this always true?]\n intersection = p1.plus(p2).dot(i1) > 0 ? i2 : i1;\n break;\n }\n break;\n case 'bearing+endpoint': // use bearing c1 × p1\n dir1 = Math.sign(c1.cross(p1).dot(i1)); // c1×p1⋅i1 +ve means p1 bearing points to i1\n intersection = dir1>0 ? i1 : i2;\n break;\n case 'endpoint+bearing': // use bearing c2 × p2\n dir2 = Math.sign(c2.cross(p2).dot(i1)); // c2×p2⋅i1 +ve means p2 bearing points to i1\n intersection = dir2>0 ? i1 : i2;\n break;\n case 'endpoint+endpoint': // select nearest intersection to mid-point of all points\n var mid = p1.plus(p2).plus(path1brngEnd.toVector()).plus(path2brngEnd.toVector());\n intersection = mid.dot(i1)>0 ? i1 : i2;\n break;\n }\n\n return intersection.toLatLonS();\n};\n\n\n/**\n * Returns (signed) distance from ‘this’ point to great circle defined by start-point and end-point/bearing.\n *\n * @param {LatLon} pathStart - Start point of great circle path.\n * @param {LatLon|number} pathBrngEnd - End point of great circle path or initial bearing from great circle start point.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance to great circle (-ve if to left, +ve if to right of path).\n *\n * @example\n * var pCurrent = new LatLon(53.2611, -0.7972);\n *\n * var p1 = new LatLon(53.3206, -1.7297), brng = 96.0;\n * var d = pCurrent.crossTrackDistanceTo(p1, brng);// -305.7 m\n *\n * var p1 = new LatLon(53.3206, -1.7297), p2 = new LatLon(53.1887, 0.1334);\n * var d = pCurrent.crossTrackDistanceTo(p1, p2); // -307.5 m\n */\nLatLon.prototype.crossTrackDistanceTo = function(pathStart, pathBrngEnd, radius) {\n if (!(pathStart instanceof LatLon)) throw new TypeError('pathStart is not LatLon object');\n var R = (radius === undefined) ? 6371e3 : Number(radius);\n\n var p = this.toVector();\n\n var gc = pathBrngEnd instanceof LatLon // (note JavaScript is not good at method overloading)\n ? pathStart.toVector().cross(pathBrngEnd.toVector()) // great circle defined by two points\n : pathStart.greatCircle(Number(pathBrngEnd)); // great circle defined by point + bearing\n\n var α = gc.angleTo(p) - Math.PI/2; // angle between point & great-circle\n\n var d = α * R;\n\n return d;\n};\n\n\n/**\n * Returns how far ‘this’ point is along a path from from start-point, heading on bearing or towards\n * end-point. That is, if a perpendicular is drawn from ‘this’ point to the (great circle) path, the\n * along-track distance is the distance from the start point to where the perpendicular crosses the\n * path.\n *\n * @param {LatLon} pathStart - Start point of great circle path.\n * @param {LatLon|number} pathBrngEnd - End point of great circle path or initial bearing from great circle start point.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance along great circle to point nearest ‘this’ point.\n *\n * @example\n * var pCurrent = new LatLon(53.2611, -0.7972);\n * var p1 = new LatLon(53.3206, -1.7297);\n * var p2 = new LatLon(53.1887, 0.1334);\n * var d = pCurrent.alongTrackDistanceTo(p1, p2); // 62.331 km\n */\nLatLon.prototype.alongTrackDistanceTo = function(pathStart, pathBrngEnd, radius) {\n if (!(pathStart instanceof LatLon)) throw new TypeError('pathStart is not LatLon object');\n var R = (radius === undefined) ? 6371e3 : Number(radius);\n\n var p = this.toVector();\n\n var gc = pathBrngEnd instanceof LatLon // (note JavaScript is not good at method overloading)\n ? pathStart.toVector().cross(pathBrngEnd.toVector()) // great circle defined by two points\n : pathStart.greatCircle(Number(pathBrngEnd)); // great circle defined by point + bearing\n\n var pat = gc.cross(p).cross(gc); // along-track point c × p × c\n\n var α = pathStart.toVector().angleTo(pat, gc); // angle between start point and along-track point\n\n var d = α * R;\n\n return d;\n};\n\n\n/**\n * Returns closest point on great circle segment between point1 & point2 to ‘this’ point.\n *\n * If this point is ‘within’ the extent of the segment, the point is on the segment between point1 &\n * point2; otherwise, it is the closer of the endpoints defining the segment.\n *\n * @param {LatLon} point1 - Start point of great circle segment.\n * @param {LatLon} point2 - End point of great circle segment.\n * @returns {number} point on segment.\n *\n * @example\n * var p1 = new LatLon(51.0, 1.0), p2 = new LatLon(51.0, 2.0);\n *\n * var p0 = new LatLon(51.0, 1.9);\n * var p = p0.nearestPointOnSegment(p1, p2); // 51.0004°N, 001.9000°E\n * var d = p.distanceTo(p); // 42.71 m\n *\n * var p0 = new LatLon(51.0, 2.1);\n * var p = p0.nearestPointOnSegment(p1, p2); // 51.0000°N, 002.0000°E\n */\nLatLon.prototype.nearestPointOnSegment = function(point1, point2) {\n var p = null;\n\n if (this.isBetween(point1, point2)) {\n // closer to segment than to its endpoints, find closest point on segment\n var n0 = this.toVector(), n1 = point1.toVector(), n2 = point2.toVector();\n var c1 = n1.cross(n2); // n1×n2 = vector representing great circle through p1, p2\n var c2 = n0.cross(c1); // n0×c1 = vector representing great circle through p0 normal to c1\n var n = c1.cross(c2); // c2×c1 = nearest point on c1 to n0\n p = n.toLatLonS();\n } else {\n // beyond segment extent, take closer endpoint\n var d1 = this.distanceTo(point1);\n var d2 = this.distanceTo(point2);\n p = d1p1, p0->p2, p1->p2, p2->p1\n var δ10 = n0.minus(n1), δ12 = n2.minus(n1);\n var δ20 = n0.minus(n2), δ21 = n1.minus(n2);\n\n // dot product δ10⋅δ12 tells us if p0 is on p2 side of p1, similarly for δ20⋅δ21\n var extent1 = δ10.dot(δ12);\n var extent2 = δ20.dot(δ21);\n\n var isBetween = extent1>=0 && extent2>=0;\n var isSameHemisphere = n0.dot(n1)>=0 && n0.dot(n2)>=0;\n\n return isBetween && isSameHemisphere;\n};\n\n\n/**\n * Tests whether ‘this’ point is enclosed by the polygon defined by a set of points.\n *\n * @param {LatLon[]} polygon - Ordered array of points defining vertices of polygon.\n * @returns {bool} Whether this point is enclosed by polygon.\n *\n * @example\n * var bounds = [ new LatLon(45,1), new LatLon(45,2), new LatLon(46,2), new LatLon(46,1) ];\n * var p = new LatLon(45.1, 1.1);\n * var inside = p.enclosedBy(bounds); // true\n */\nLatLon.prototype.enclosedBy = function(polygon) {\n // this method uses angle summation test; on a plane, angles for an enclosed point will sum\n // to 360°, angles for an exterior point will sum to 0°. On a sphere, enclosed point angles\n // will sum to less than 360° (due to spherical excess), exterior point angles will be small\n // but non-zero. TODO: are any winding number optimisations applicable to spherical surface?\n\n // close the polygon so that the last point equals the first point\n var closed = polygon[0].equals(polygon[polygon.length-1]);\n if (!closed) polygon.push(polygon[0]);\n\n var nVertices = polygon.length - 1;\n\n var p = this.toVector();\n\n // get vectors from p to each vertex\n var vectorToVertex = [];\n for (var v=0; v Math.PI;\n\n if (!closed) polygon.pop(); // restore polygon to pristine condition\n\n return enclosed;\n};\n\n\n/**\n * Calculates the area of a spherical polygon where the sides of the polygon are great circle\n * arcs joining the vertices.\n *\n * @param {LatLon[]} polygon - Array of points defining vertices of the polygon.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} The area of the polygon in the same units as radius.\n *\n * @example\n * var polygon = [ new LatLon(0,0), new LatLon(1,0), new LatLon(0,1) ];\n * var area = LatLon.areaOf(polygon); // 6.18e9 m²\n */\nLatLon.areaOf = function(polygon, radius) {\n // uses Girard’s theorem: A = [Σθᵢ − (n−2)·π]·R²\n\n var R = (radius == undefined) ? 6371e3 : Number(radius);\n\n // close the polygon so that the last point equals the first point\n var closed = polygon[0].equals(polygon[polygon.length-1]);\n if (!closed) polygon.push(polygon[0]);\n\n var n = polygon.length - 1; // number of vertices\n\n // get great-circle vector for each edge\n var c = [];\n for (var v=0; v 0 ? 1 : -1;\n };\n}\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = LatLon, module.exports.Vector3d = Vector3d; // ≡ export { LatLon as default, Vector3d }\n","function flatten(gj) {\n switch ((gj && gj.type) || null) {\n case 'FeatureCollection':\n gj.features = gj.features.reduce(function(mem, feature) {\n return mem.concat(flatten(feature));\n }, []);\n return gj;\n case 'Feature':\n if (!gj.geometry) return gj;\n return flatten(gj.geometry).map(function(geom) {\n return {\n type: 'Feature',\n properties: JSON.parse(JSON.stringify(gj.properties)),\n geometry: geom\n };\n });\n case 'MultiPoint':\n return gj.coordinates.map(function(_) {\n return { type: 'Point', coordinates: _ };\n });\n case 'MultiPolygon':\n return gj.coordinates.map(function(_) {\n return { type: 'Polygon', coordinates: _ };\n });\n case 'MultiLineString':\n return gj.coordinates.map(function(_) {\n return { type: 'LineString', coordinates: _ };\n });\n case 'GeometryCollection':\n return gj.geometries.map(flatten).reduce(function(memo, geoms) {\n return memo.concat(geoms);\n }, []);\n case 'Point':\n case 'Polygon':\n case 'LineString':\n return [gj];\n }\n}\n\nmodule.exports = flatten;\n","var measureDistance = require('@turf/distance');\nvar point = require('@turf/helpers').point;\nvar bearing = require('@turf/bearing');\nvar destination = require('@turf/destination');\n\n/**\n * Takes a {@link LineString|line} and returns a {@link Point|point} at a specified distance along the line.\n *\n * @name along\n * @param {Feature} line input line\n * @param {number} distance distance along the line\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {Feature} Point `distance` `units` along the line\n * @example\n * var line = turf.lineString([[-83, 30], [-84, 36], [-78, 41]]);\n *\n * var along = turf.along(line, 200, 'miles');\n *\n * //addToMap\n * var addToMap = [along, line]\n */\nmodule.exports = function (line, distance, units) {\n var coords;\n if (line.type === 'Feature') coords = line.geometry.coordinates;\n else if (line.type === 'LineString') coords = line.coordinates;\n else throw new Error('input must be a LineString Feature or Geometry');\n\n var travelled = 0;\n for (var i = 0; i < coords.length; i++) {\n if (distance >= travelled && i === coords.length - 1) break;\n else if (travelled >= distance) {\n var overshot = distance - travelled;\n if (!overshot) return point(coords[i]);\n else {\n var direction = bearing(coords[i], coords[i - 1]) - 180;\n var interpolated = destination(coords[i], overshot, direction, units);\n return interpolated;\n }\n } else {\n travelled += measureDistance(coords[i], coords[i + 1], units);\n }\n }\n return point(coords[coords.length - 1]);\n};\n","// http://stackoverflow.com/questions/11935175/sampling-a-random-subset-from-an-array\nvar featureCollection = require('@turf/helpers').featureCollection;\n\n/**\n * Takes a {@link FeatureCollection} and returns a FeatureCollection with given number of {@link Feature|features} at random.\n *\n * @name sample\n * @param {FeatureCollection} featurecollection set of input features\n * @param {number} num number of features to select\n * @returns {FeatureCollection} a FeatureCollection with `n` features\n * @example\n * var points = turf.random('points', 100, {\n * bbox: [-80, 30, -60, 60]\n * });\n *\n * var sample = turf.sample(points, 5);\n *\n * //addToMap\n * var addToMap = [points, sample]\n * turf.featureEach(sample, function (currentFeature) {\n * currentFeature.properties['marker-size'] = 'large';\n * currentFeature.properties['marker-color'] = '#000';\n * });\n */\nmodule.exports = function (featurecollection, num) {\n var outFC = featureCollection(getRandomSubarray(featurecollection.features, num));\n return outFC;\n};\n\nfunction getRandomSubarray(arr, size) {\n var shuffled = arr.slice(0), i = arr.length, min = i - size, temp, index;\n while (i-- > min) {\n index = Math.floor((i + 1) * Math.random());\n temp = shuffled[index];\n shuffled[index] = shuffled[i];\n shuffled[i] = temp;\n }\n return shuffled.slice(min);\n}\n","/*!\n* @license GNU Affero General Public License.\n* Copyright (c) 2015, 2015 Ronny Lorenz \n* v. 1.2.0\n* https://github.com/RaumZeit/MarchingSquares.js\n*/\n\n(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define([], function() { return { isoBands : factory() }; })\n } else if (typeof module === 'object' && module.exports) {\n // Node. Does not work with strict CommonJS, but\n // only CommonJS-like environments that support module.exports,\n // like Node.\n module.exports = { isoBands : factory() };\n } else {\n // Browser globals (root is window)\n root.MarchingSquaresJS = {\n isoBands : factory(),\n isoContours : (root.MarchingSquaresJS) ? root.MarchingSquaresJS.isoContours : null\n };\n }\n}(this, function () {\n\n var defaultSettings = {\n successCallback: null,\n verbose: false,\n polygons: false\n };\n \n var settings = {};\n \n /*\n Compute isobands(s) of a scalar 2D field given a certain\n threshold and a bandwidth by applying the Marching Squares\n Algorithm. The function returns a list of path coordinates\n either for individual polygons within each grid cell, or the\n outline of connected polygons.\n */\n function isoBands(data, minV, bandwidth, options){\n /* process options */\n options = options ? options : {};\n\n var optionKeys = Object.keys(defaultSettings);\n\n for(var i = 0; i < optionKeys.length; i++){\n var key = optionKeys[i];\n var val = options[key];\n val = ((typeof val !== 'undefined') && (val !== null)) ? val : defaultSettings[key];\n\n settings[key] = val;\n }\n\n if(settings.verbose)\n console.log(\"MarchingSquaresJS-isoBands: computing isobands for [\" + minV + \":\" + (minV + bandwidth) + \"]\");\n\n var grid = computeBandGrid(data, minV, bandwidth);\n\n var ret;\n if(settings.polygons){\n if (settings.verbose)\n console.log(\"MarchingSquaresJS-isoBands: returning single polygons for each grid cell\");\n ret = BandGrid2Areas(grid);\n } else {\n if (settings.verbose)\n console.log(\"MarchingSquaresJS-isoBands: returning polygon paths for entire data grid\");\n ret = BandGrid2AreaPaths(grid);\n }\n\n if(typeof settings.successCallback === 'function')\n settings.successCallback(ret);\n\n return ret;\n }\n\n /*\n Thats all for the public interface, below follows the actual\n implementation\n */\n\n /* Some private variables */\n var Node0 = 64,\n Node1 = 16,\n Node2 = 4,\n Node3 = 1;\n\n /* For isoBands, each square is defined by the three states\n of its corner points. However, since computers use power-2\n values, we use 2bits per trit, i.e.:\n\n 00 ... below minV\n 01 ... between minV and maxV\n 10 ... above maxV\n\n Hence we map the 4-trit configurations as follows:\n\n 0000 => 0\n 0001 => 1\n 0002 => 2\n 0010 => 4\n 0011 => 5\n 0012 => 6\n 0020 => 8\n 0021 => 9\n 0022 => 10\n 0100 => 16\n 0101 => 17\n 0102 => 18\n 0110 => 20\n 0111 => 21\n 0112 => 22\n 0120 => 24\n 0121 => 25\n 0122 => 26\n 0200 => 32\n 0201 => 33\n 0202 => 34\n 0210 => 36\n 0211 => 37\n 0212 => 38\n 0220 => 40\n 0221 => 41\n 0222 => 42\n 1000 => 64\n 1001 => 65\n 1002 => 66\n 1010 => 68\n 1011 => 69\n 1012 => 70\n 1020 => 72\n 1021 => 73\n 1022 => 74\n 1100 => 80\n 1101 => 81\n 1102 => 82\n 1110 => 84\n 1111 => 85\n 1112 => 86\n 1120 => 88\n 1121 => 89\n 1122 => 90\n 1200 => 96\n 1201 => 97\n 1202 => 98\n 1210 => 100\n 1211 => 101\n 1212 => 102\n 1220 => 104\n 1221 => 105\n 1222 => 106\n 2000 => 128\n 2001 => 129\n 2002 => 130\n 2010 => 132\n 2011 => 133\n 2012 => 134\n 2020 => 136\n 2021 => 137\n 2022 => 138\n 2100 => 144\n 2101 => 145\n 2102 => 146\n 2110 => 148\n 2111 => 149\n 2112 => 150\n 2120 => 152\n 2121 => 153\n 2122 => 154\n 2200 => 160\n 2201 => 161\n 2202 => 162\n 2210 => 164\n 2211 => 165\n 2212 => 166\n 2220 => 168\n 2221 => 169\n 2222 => 170\n */\n\n /*\n The look-up tables for tracing back the contour path\n of isoBands\n */\n\n var isoBandNextXTL = [];\n var isoBandNextYTL = [];\n var isoBandNextOTL = [];\n\n var isoBandNextXTR = [];\n var isoBandNextYTR = [];\n var isoBandNextOTR = [];\n\n var isoBandNextXRT = [];\n var isoBandNextYRT = [];\n var isoBandNextORT = [];\n\n var isoBandNextXRB = [];\n var isoBandNextYRB = [];\n var isoBandNextORB = [];\n\n var isoBandNextXBL = [];\n var isoBandNextYBL = [];\n var isoBandNextOBL = [];\n\n var isoBandNextXBR = [];\n var isoBandNextYBR = [];\n var isoBandNextOBR = [];\n\n var isoBandNextXLT = [];\n var isoBandNextYLT = [];\n var isoBandNextOLT = [];\n\n var isoBandNextXLB = [];\n var isoBandNextYLB = [];\n var isoBandNextOLB = [];\n\n isoBandNextXRT[85] = isoBandNextXRB[85] = -1;\n isoBandNextYRT[85] = isoBandNextYRB[85] = 0;\n isoBandNextORT[85] = isoBandNextORB[85] = 1;\n isoBandNextXLT[85] = isoBandNextXLB[85] = 1;\n isoBandNextYLT[85] = isoBandNextYLB[85] = 0;\n isoBandNextOLT[85] = isoBandNextOLB[85] = 1;\n\n isoBandNextXTL[85] = isoBandNextXTR[85] = 0;\n isoBandNextYTL[85] = isoBandNextYTR[85] = -1;\n isoBandNextOTL[85] = isoBandNextOBL[85] = 0;\n isoBandNextXBR[85] = isoBandNextXBL[85] = 0;\n isoBandNextYBR[85] = isoBandNextYBL[85] = 1;\n isoBandNextOTR[85] = isoBandNextOBR[85] = 1;\n\n\n /* triangle cases */\n isoBandNextXLB[1] = isoBandNextXLB[169] = 0;\n isoBandNextYLB[1] = isoBandNextYLB[169] = -1;\n isoBandNextOLB[1] = isoBandNextOLB[169] = 0;\n isoBandNextXBL[1] = isoBandNextXBL[169] = -1;\n isoBandNextYBL[1] = isoBandNextYBL[169] = 0;\n isoBandNextOBL[1] = isoBandNextOBL[169] = 0;\n\n isoBandNextXRB[4] = isoBandNextXRB[166] = 0;\n isoBandNextYRB[4] = isoBandNextYRB[166] = -1;\n isoBandNextORB[4] = isoBandNextORB[166] = 1;\n isoBandNextXBR[4] = isoBandNextXBR[166] = 1;\n isoBandNextYBR[4] = isoBandNextYBR[166] = 0;\n isoBandNextOBR[4] = isoBandNextOBR[166] = 0;\n\n isoBandNextXRT[16] = isoBandNextXRT[154] = 0;\n isoBandNextYRT[16] = isoBandNextYRT[154] = 1;\n isoBandNextORT[16] = isoBandNextORT[154] = 1;\n isoBandNextXTR[16] = isoBandNextXTR[154] = 1;\n isoBandNextYTR[16] = isoBandNextYTR[154] = 0;\n isoBandNextOTR[16] = isoBandNextOTR[154] = 1;\n\n isoBandNextXLT[64] = isoBandNextXLT[106] = 0;\n isoBandNextYLT[64] = isoBandNextYLT[106] = 1;\n isoBandNextOLT[64] = isoBandNextOLT[106] = 0;\n isoBandNextXTL[64] = isoBandNextXTL[106] = -1;\n isoBandNextYTL[64] = isoBandNextYTL[106] = 0;\n isoBandNextOTL[64] = isoBandNextOTL[106] = 1;\n\n /* single trapezoid cases */\n isoBandNextXLT[2] = isoBandNextXLT[168] = 0;\n isoBandNextYLT[2] = isoBandNextYLT[168] = -1;\n isoBandNextOLT[2] = isoBandNextOLT[168] = 1;\n isoBandNextXLB[2] = isoBandNextXLB[168] = 0;\n isoBandNextYLB[2] = isoBandNextYLB[168] = -1;\n isoBandNextOLB[2] = isoBandNextOLB[168] = 0;\n isoBandNextXBL[2] = isoBandNextXBL[168] = -1;\n isoBandNextYBL[2] = isoBandNextYBL[168] = 0;\n isoBandNextOBL[2] = isoBandNextOBL[168] = 0;\n isoBandNextXBR[2] = isoBandNextXBR[168] = -1;\n isoBandNextYBR[2] = isoBandNextYBR[168] = 0;\n isoBandNextOBR[2] = isoBandNextOBR[168] = 1;\n\n isoBandNextXRT[8] = isoBandNextXRT[162] = 0;\n isoBandNextYRT[8] = isoBandNextYRT[162] = -1;\n isoBandNextORT[8] = isoBandNextORT[162] = 0;\n isoBandNextXRB[8] = isoBandNextXRB[162] = 0;\n isoBandNextYRB[8] = isoBandNextYRB[162] = -1;\n isoBandNextORB[8] = isoBandNextORB[162] = 1;\n isoBandNextXBL[8] = isoBandNextXBL[162] = 1;\n isoBandNextYBL[8] = isoBandNextYBL[162] = 0;\n isoBandNextOBL[8] = isoBandNextOBL[162] = 1;\n isoBandNextXBR[8] = isoBandNextXBR[162] = 1;\n isoBandNextYBR[8] = isoBandNextYBR[162] = 0;\n isoBandNextOBR[8] = isoBandNextOBR[162] = 0;\n\n isoBandNextXRT[32] = isoBandNextXRT[138] = 0;\n isoBandNextYRT[32] = isoBandNextYRT[138] = 1;\n isoBandNextORT[32] = isoBandNextORT[138] = 1;\n isoBandNextXRB[32] = isoBandNextXRB[138] = 0;\n isoBandNextYRB[32] = isoBandNextYRB[138] = 1;\n isoBandNextORB[32] = isoBandNextORB[138] = 0;\n isoBandNextXTL[32] = isoBandNextXTL[138] = 1;\n isoBandNextYTL[32] = isoBandNextYTL[138] = 0;\n isoBandNextOTL[32] = isoBandNextOTL[138] = 0;\n isoBandNextXTR[32] = isoBandNextXTR[138] = 1;\n isoBandNextYTR[32] = isoBandNextYTR[138] = 0;\n isoBandNextOTR[32] = isoBandNextOTR[138] = 1;\n\n isoBandNextXLB[128] = isoBandNextXLB[42] = 0;\n isoBandNextYLB[128] = isoBandNextYLB[42] = 1;\n isoBandNextOLB[128] = isoBandNextOLB[42] = 1;\n isoBandNextXLT[128] = isoBandNextXLT[42] = 0;\n isoBandNextYLT[128] = isoBandNextYLT[42] = 1;\n isoBandNextOLT[128] = isoBandNextOLT[42] = 0;\n isoBandNextXTL[128] = isoBandNextXTL[42] = -1;\n isoBandNextYTL[128] = isoBandNextYTL[42] = 0;\n isoBandNextOTL[128] = isoBandNextOTL[42] = 1;\n isoBandNextXTR[128] = isoBandNextXTR[42] = -1;\n isoBandNextYTR[128] = isoBandNextYTR[42] = 0;\n isoBandNextOTR[128] = isoBandNextOTR[42] = 0;\n\n /* single rectangle cases */\n isoBandNextXRB[5] = isoBandNextXRB[165] = -1;\n isoBandNextYRB[5] = isoBandNextYRB[165] = 0;\n isoBandNextORB[5] = isoBandNextORB[165] = 0;\n isoBandNextXLB[5] = isoBandNextXLB[165] = 1;\n isoBandNextYLB[5] = isoBandNextYLB[165] = 0;\n isoBandNextOLB[5] = isoBandNextOLB[165] = 0;\n\n isoBandNextXBR[20] = isoBandNextXBR[150] = 0;\n isoBandNextYBR[20] = isoBandNextYBR[150] = 1;\n isoBandNextOBR[20] = isoBandNextOBR[150] = 1;\n isoBandNextXTR[20] = isoBandNextXTR[150] = 0;\n isoBandNextYTR[20] = isoBandNextYTR[150] = -1;\n isoBandNextOTR[20] = isoBandNextOTR[150] = 1;\n\n isoBandNextXRT[80] = isoBandNextXRT[90] = -1;\n isoBandNextYRT[80] = isoBandNextYRT[90] = 0;\n isoBandNextORT[80] = isoBandNextORT[90] = 1;\n isoBandNextXLT[80] = isoBandNextXLT[90] = 1;\n isoBandNextYLT[80] = isoBandNextYLT[90] = 0;\n isoBandNextOLT[80] = isoBandNextOLT[90] = 1;\n\n isoBandNextXBL[65] = isoBandNextXBL[105] = 0;\n isoBandNextYBL[65] = isoBandNextYBL[105] = 1;\n isoBandNextOBL[65] = isoBandNextOBL[105] = 0;\n isoBandNextXTL[65] = isoBandNextXTL[105] = 0;\n isoBandNextYTL[65] = isoBandNextYTL[105] = -1;\n isoBandNextOTL[65] = isoBandNextOTL[105] = 0;\n\n isoBandNextXRT[160] = isoBandNextXRT[10] = -1;\n isoBandNextYRT[160] = isoBandNextYRT[10] = 0;\n isoBandNextORT[160] = isoBandNextORT[10] = 1;\n isoBandNextXRB[160] = isoBandNextXRB[10] = -1;\n isoBandNextYRB[160] = isoBandNextYRB[10] = 0;\n isoBandNextORB[160] = isoBandNextORB[10] = 0;\n isoBandNextXLB[160] = isoBandNextXLB[10] = 1;\n isoBandNextYLB[160] = isoBandNextYLB[10] = 0;\n isoBandNextOLB[160] = isoBandNextOLB[10] = 0;\n isoBandNextXLT[160] = isoBandNextXLT[10] = 1;\n isoBandNextYLT[160] = isoBandNextYLT[10] = 0;\n isoBandNextOLT[160] = isoBandNextOLT[10] = 1;\n\n isoBandNextXBR[130] = isoBandNextXBR[40] = 0;\n isoBandNextYBR[130] = isoBandNextYBR[40] = 1;\n isoBandNextOBR[130] = isoBandNextOBR[40] = 1;\n isoBandNextXBL[130] = isoBandNextXBL[40] = 0;\n isoBandNextYBL[130] = isoBandNextYBL[40] = 1;\n isoBandNextOBL[130] = isoBandNextOBL[40] = 0;\n isoBandNextXTL[130] = isoBandNextXTL[40] = 0;\n isoBandNextYTL[130] = isoBandNextYTL[40] = -1;\n isoBandNextOTL[130] = isoBandNextOTL[40] = 0;\n isoBandNextXTR[130] = isoBandNextXTR[40] = 0;\n isoBandNextYTR[130] = isoBandNextYTR[40] = -1;\n isoBandNextOTR[130] = isoBandNextOTR[40] = 1;\n\n /* single hexagon cases */\n isoBandNextXRB[37] = isoBandNextXRB[133] = 0;\n isoBandNextYRB[37] = isoBandNextYRB[133] = 1;\n isoBandNextORB[37] = isoBandNextORB[133] = 1;\n isoBandNextXLB[37] = isoBandNextXLB[133] = 0;\n isoBandNextYLB[37] = isoBandNextYLB[133] = 1;\n isoBandNextOLB[37] = isoBandNextOLB[133] = 0;\n isoBandNextXTL[37] = isoBandNextXTL[133] = -1;\n isoBandNextYTL[37] = isoBandNextYTL[133] = 0;\n isoBandNextOTL[37] = isoBandNextOTL[133] = 0;\n isoBandNextXTR[37] = isoBandNextXTR[133] = 1;\n isoBandNextYTR[37] = isoBandNextYTR[133] = 0;\n isoBandNextOTR[37] = isoBandNextOTR[133] = 0;\n\n isoBandNextXBR[148] = isoBandNextXBR[22] = -1;\n isoBandNextYBR[148] = isoBandNextYBR[22] = 0;\n isoBandNextOBR[148] = isoBandNextOBR[22] = 0;\n isoBandNextXLB[148] = isoBandNextXLB[22] = 0;\n isoBandNextYLB[148] = isoBandNextYLB[22] = -1;\n isoBandNextOLB[148] = isoBandNextOLB[22] = 1;\n isoBandNextXLT[148] = isoBandNextXLT[22] = 0;\n isoBandNextYLT[148] = isoBandNextYLT[22] = 1;\n isoBandNextOLT[148] = isoBandNextOLT[22] = 1;\n isoBandNextXTR[148] = isoBandNextXTR[22] = -1;\n isoBandNextYTR[148] = isoBandNextYTR[22] = 0;\n isoBandNextOTR[148] = isoBandNextOTR[22] = 1;\n\n isoBandNextXRT[82] = isoBandNextXRT[88] = 0;\n isoBandNextYRT[82] = isoBandNextYRT[88] = -1;\n isoBandNextORT[82] = isoBandNextORT[88] = 1;\n isoBandNextXBR[82] = isoBandNextXBR[88] = 1;\n isoBandNextYBR[82] = isoBandNextYBR[88] = 0;\n isoBandNextOBR[82] = isoBandNextOBR[88] = 1;\n isoBandNextXBL[82] = isoBandNextXBL[88] = -1;\n isoBandNextYBL[82] = isoBandNextYBL[88] = 0;\n isoBandNextOBL[82] = isoBandNextOBL[88] = 1;\n isoBandNextXLT[82] = isoBandNextXLT[88] = 0;\n isoBandNextYLT[82] = isoBandNextYLT[88] = -1;\n isoBandNextOLT[82] = isoBandNextOLT[88] = 0;\n\n isoBandNextXRT[73] = isoBandNextXRT[97] = 0;\n isoBandNextYRT[73] = isoBandNextYRT[97] = 1;\n isoBandNextORT[73] = isoBandNextORT[97] = 0;\n isoBandNextXRB[73] = isoBandNextXRB[97] = 0;\n isoBandNextYRB[73] = isoBandNextYRB[97] = -1;\n isoBandNextORB[73] = isoBandNextORB[97] = 0;\n isoBandNextXBL[73] = isoBandNextXBL[97] = 1;\n isoBandNextYBL[73] = isoBandNextYBL[97] = 0;\n isoBandNextOBL[73] = isoBandNextOBL[97] = 0;\n isoBandNextXTL[73] = isoBandNextXTL[97] = 1;\n isoBandNextYTL[73] = isoBandNextYTL[97] = 0;\n isoBandNextOTL[73] = isoBandNextOTL[97] = 1;\n\n isoBandNextXRT[145] = isoBandNextXRT[25] = 0;\n isoBandNextYRT[145] = isoBandNextYRT[25] = -1;\n isoBandNextORT[145] = isoBandNextORT[25] = 0;\n isoBandNextXBL[145] = isoBandNextXBL[25] = 1;\n isoBandNextYBL[145] = isoBandNextYBL[25] = 0;\n isoBandNextOBL[145] = isoBandNextOBL[25] = 1;\n isoBandNextXLB[145] = isoBandNextXLB[25] = 0;\n isoBandNextYLB[145] = isoBandNextYLB[25] = 1;\n isoBandNextOLB[145] = isoBandNextOLB[25] = 1;\n isoBandNextXTR[145] = isoBandNextXTR[25] = -1;\n isoBandNextYTR[145] = isoBandNextYTR[25] = 0;\n isoBandNextOTR[145] = isoBandNextOTR[25] = 0;\n\n isoBandNextXRB[70] = isoBandNextXRB[100] = 0;\n isoBandNextYRB[70] = isoBandNextYRB[100] = 1;\n isoBandNextORB[70] = isoBandNextORB[100] = 0;\n isoBandNextXBR[70] = isoBandNextXBR[100] = -1;\n isoBandNextYBR[70] = isoBandNextYBR[100] = 0;\n isoBandNextOBR[70] = isoBandNextOBR[100] = 1;\n isoBandNextXLT[70] = isoBandNextXLT[100] = 0;\n isoBandNextYLT[70] = isoBandNextYLT[100] = -1;\n isoBandNextOLT[70] = isoBandNextOLT[100] = 1;\n isoBandNextXTL[70] = isoBandNextXTL[100] = 1;\n isoBandNextYTL[70] = isoBandNextYTL[100] = 0;\n isoBandNextOTL[70] = isoBandNextOTL[100] = 0;\n\n /* single pentagon cases */\n isoBandNextXRB[101] = isoBandNextXRB[69] = 0;\n isoBandNextYRB[101] = isoBandNextYRB[69] = 1;\n isoBandNextORB[101] = isoBandNextORB[69] = 0;\n isoBandNextXTL[101] = isoBandNextXTL[69] = 1;\n isoBandNextYTL[101] = isoBandNextYTL[69] = 0;\n isoBandNextOTL[101] = isoBandNextOTL[69] = 0;\n\n isoBandNextXLB[149] = isoBandNextXLB[21] = 0;\n isoBandNextYLB[149] = isoBandNextYLB[21] = 1;\n isoBandNextOLB[149] = isoBandNextOLB[21] = 1;\n isoBandNextXTR[149] = isoBandNextXTR[21] = -1;\n isoBandNextYTR[149] = isoBandNextYTR[21] = 0;\n isoBandNextOTR[149] = isoBandNextOTR[21] = 0;\n\n isoBandNextXBR[86] = isoBandNextXBR[84] = -1;\n isoBandNextYBR[86] = isoBandNextYBR[84] = 0;\n isoBandNextOBR[86] = isoBandNextOBR[84] = 1;\n isoBandNextXLT[86] = isoBandNextXLT[84] = 0;\n isoBandNextYLT[86] = isoBandNextYLT[84] = -1;\n isoBandNextOLT[86] = isoBandNextOLT[84] = 1;\n\n isoBandNextXRT[89] = isoBandNextXRT[81] = 0;\n isoBandNextYRT[89] = isoBandNextYRT[81] = -1;\n isoBandNextORT[89] = isoBandNextORT[81] = 0;\n isoBandNextXBL[89] = isoBandNextXBL[81] = 1;\n isoBandNextYBL[89] = isoBandNextYBL[81] = 0;\n isoBandNextOBL[89] = isoBandNextOBL[81] = 1;\n\n isoBandNextXRT[96] = isoBandNextXRT[74] = 0;\n isoBandNextYRT[96] = isoBandNextYRT[74] = 1;\n isoBandNextORT[96] = isoBandNextORT[74] = 0;\n isoBandNextXRB[96] = isoBandNextXRB[74] = -1;\n isoBandNextYRB[96] = isoBandNextYRB[74] = 0;\n isoBandNextORB[96] = isoBandNextORB[74] = 1;\n isoBandNextXLT[96] = isoBandNextXLT[74] = 1;\n isoBandNextYLT[96] = isoBandNextYLT[74] = 0;\n isoBandNextOLT[96] = isoBandNextOLT[74] = 0;\n isoBandNextXTL[96] = isoBandNextXTL[74] = 1;\n isoBandNextYTL[96] = isoBandNextYTL[74] = 0;\n isoBandNextOTL[96] = isoBandNextOTL[74] = 1;\n\n isoBandNextXRT[24] = isoBandNextXRT[146] = 0;\n isoBandNextYRT[24] = isoBandNextYRT[146] = -1;\n isoBandNextORT[24] = isoBandNextORT[146] = 1;\n isoBandNextXBR[24] = isoBandNextXBR[146] = 1;\n isoBandNextYBR[24] = isoBandNextYBR[146] = 0;\n isoBandNextOBR[24] = isoBandNextOBR[146] = 1;\n isoBandNextXBL[24] = isoBandNextXBL[146] = 0;\n isoBandNextYBL[24] = isoBandNextYBL[146] = 1;\n isoBandNextOBL[24] = isoBandNextOBL[146] = 1;\n isoBandNextXTR[24] = isoBandNextXTR[146] = 0;\n isoBandNextYTR[24] = isoBandNextYTR[146] = -1;\n isoBandNextOTR[24] = isoBandNextOTR[146] = 0;\n\n isoBandNextXRB[6] = isoBandNextXRB[164] = -1;\n isoBandNextYRB[6] = isoBandNextYRB[164] = 0;\n isoBandNextORB[6] = isoBandNextORB[164] = 1;\n isoBandNextXBR[6] = isoBandNextXBR[164] = -1;\n isoBandNextYBR[6] = isoBandNextYBR[164] = 0;\n isoBandNextOBR[6] = isoBandNextOBR[164] = 0;\n isoBandNextXLB[6] = isoBandNextXLB[164] = 0;\n isoBandNextYLB[6] = isoBandNextYLB[164] = -1;\n isoBandNextOLB[6] = isoBandNextOLB[164] = 1;\n isoBandNextXLT[6] = isoBandNextXLT[164] = 1;\n isoBandNextYLT[6] = isoBandNextYLT[164] = 0;\n isoBandNextOLT[6] = isoBandNextOLT[164] = 0;\n\n isoBandNextXBL[129] = isoBandNextXBL[41] = 0;\n isoBandNextYBL[129] = isoBandNextYBL[41] = 1;\n isoBandNextOBL[129] = isoBandNextOBL[41] = 1;\n isoBandNextXLB[129] = isoBandNextXLB[41] = 0;\n isoBandNextYLB[129] = isoBandNextYLB[41] = 1;\n isoBandNextOLB[129] = isoBandNextOLB[41] = 0;\n isoBandNextXTL[129] = isoBandNextXTL[41] = -1;\n isoBandNextYTL[129] = isoBandNextYTL[41] = 0;\n isoBandNextOTL[129] = isoBandNextOTL[41] = 0;\n isoBandNextXTR[129] = isoBandNextXTR[41] = 0;\n isoBandNextYTR[129] = isoBandNextYTR[41] = -1;\n isoBandNextOTR[129] = isoBandNextOTR[41] = 0;\n\n isoBandNextXBR[66] = isoBandNextXBR[104] = 0;\n isoBandNextYBR[66] = isoBandNextYBR[104] = 1;\n isoBandNextOBR[66] = isoBandNextOBR[104] = 0;\n isoBandNextXBL[66] = isoBandNextXBL[104] = -1;\n isoBandNextYBL[66] = isoBandNextYBL[104] = 0;\n isoBandNextOBL[66] = isoBandNextOBL[104] = 1;\n isoBandNextXLT[66] = isoBandNextXLT[104] = 0;\n isoBandNextYLT[66] = isoBandNextYLT[104] = -1;\n isoBandNextOLT[66] = isoBandNextOLT[104] = 0;\n isoBandNextXTL[66] = isoBandNextXTL[104] = 0;\n isoBandNextYTL[66] = isoBandNextYTL[104] = -1;\n isoBandNextOTL[66] = isoBandNextOTL[104] = 1;\n\n isoBandNextXRT[144] = isoBandNextXRT[26] = -1;\n isoBandNextYRT[144] = isoBandNextYRT[26] = 0;\n isoBandNextORT[144] = isoBandNextORT[26] = 0;\n isoBandNextXLB[144] = isoBandNextXLB[26] = 1;\n isoBandNextYLB[144] = isoBandNextYLB[26] = 0;\n isoBandNextOLB[144] = isoBandNextOLB[26] = 1;\n isoBandNextXLT[144] = isoBandNextXLT[26] = 0;\n isoBandNextYLT[144] = isoBandNextYLT[26] = 1;\n isoBandNextOLT[144] = isoBandNextOLT[26] = 1;\n isoBandNextXTR[144] = isoBandNextXTR[26] = -1;\n isoBandNextYTR[144] = isoBandNextYTR[26] = 0;\n isoBandNextOTR[144] = isoBandNextOTR[26] = 1;\n\n isoBandNextXRB[36] = isoBandNextXRB[134] = 0;\n isoBandNextYRB[36] = isoBandNextYRB[134] = 1;\n isoBandNextORB[36] = isoBandNextORB[134] = 1;\n isoBandNextXBR[36] = isoBandNextXBR[134] = 0;\n isoBandNextYBR[36] = isoBandNextYBR[134] = 1;\n isoBandNextOBR[36] = isoBandNextOBR[134] = 0;\n isoBandNextXTL[36] = isoBandNextXTL[134] = 0;\n isoBandNextYTL[36] = isoBandNextYTL[134] = -1;\n isoBandNextOTL[36] = isoBandNextOTL[134] = 1;\n isoBandNextXTR[36] = isoBandNextXTR[134] = 1;\n isoBandNextYTR[36] = isoBandNextYTR[134] = 0;\n isoBandNextOTR[36] = isoBandNextOTR[134] = 0;\n\n isoBandNextXRT[9] = isoBandNextXRT[161] = -1;\n isoBandNextYRT[9] = isoBandNextYRT[161] = 0;\n isoBandNextORT[9] = isoBandNextORT[161] = 0;\n isoBandNextXRB[9] = isoBandNextXRB[161] = 0;\n isoBandNextYRB[9] = isoBandNextYRB[161] = -1;\n isoBandNextORB[9] = isoBandNextORB[161] = 0;\n isoBandNextXBL[9] = isoBandNextXBL[161] = 1;\n isoBandNextYBL[9] = isoBandNextYBL[161] = 0;\n isoBandNextOBL[9] = isoBandNextOBL[161] = 0;\n isoBandNextXLB[9] = isoBandNextXLB[161] = 1;\n isoBandNextYLB[9] = isoBandNextYLB[161] = 0;\n isoBandNextOLB[9] = isoBandNextOLB[161] = 1;\n\n /* 8-sided cases */\n isoBandNextXRT[136] = 0;\n isoBandNextYRT[136] = 1;\n isoBandNextORT[136] = 1;\n isoBandNextXRB[136] = 0;\n isoBandNextYRB[136] = 1;\n isoBandNextORB[136] = 0;\n isoBandNextXBR[136] = -1;\n isoBandNextYBR[136] = 0;\n isoBandNextOBR[136] = 1;\n isoBandNextXBL[136] = -1;\n isoBandNextYBL[136] = 0;\n isoBandNextOBL[136] = 0;\n isoBandNextXLB[136] = 0;\n isoBandNextYLB[136] = -1;\n isoBandNextOLB[136] = 0;\n isoBandNextXLT[136] = 0;\n isoBandNextYLT[136] = -1;\n isoBandNextOLT[136] = 1;\n isoBandNextXTL[136] = 1;\n isoBandNextYTL[136] = 0;\n isoBandNextOTL[136] = 0;\n isoBandNextXTR[136] = 1;\n isoBandNextYTR[136] = 0;\n isoBandNextOTR[136] = 1;\n\n isoBandNextXRT[34] = 0;\n isoBandNextYRT[34] = -1;\n isoBandNextORT[34] = 0;\n isoBandNextXRB[34] = 0;\n isoBandNextYRB[34] = -1;\n isoBandNextORB[34] = 1;\n isoBandNextXBR[34] = 1;\n isoBandNextYBR[34] = 0;\n isoBandNextOBR[34] = 0;\n isoBandNextXBL[34] = 1;\n isoBandNextYBL[34] = 0;\n isoBandNextOBL[34] = 1;\n isoBandNextXLB[34] = 0;\n isoBandNextYLB[34] = 1;\n isoBandNextOLB[34] = 1;\n isoBandNextXLT[34] = 0;\n isoBandNextYLT[34] = 1;\n isoBandNextOLT[34] = 0;\n isoBandNextXTL[34] = -1;\n isoBandNextYTL[34] = 0;\n isoBandNextOTL[34] = 1;\n isoBandNextXTR[34] = -1;\n isoBandNextYTR[34] = 0;\n isoBandNextOTR[34] = 0;\n\n isoBandNextXRT[35] = 0;\n isoBandNextYRT[35] = 1;\n isoBandNextORT[35] = 1;\n isoBandNextXRB[35] = 0;\n isoBandNextYRB[35] = -1;\n isoBandNextORB[35] = 1;\n isoBandNextXBR[35] = 1;\n isoBandNextYBR[35] = 0;\n isoBandNextOBR[35] = 0;\n isoBandNextXBL[35] = -1;\n isoBandNextYBL[35] = 0;\n isoBandNextOBL[35] = 0;\n isoBandNextXLB[35] = 0;\n isoBandNextYLB[35] = -1;\n isoBandNextOLB[35] = 0;\n isoBandNextXLT[35] = 0;\n isoBandNextYLT[35] = 1;\n isoBandNextOLT[35] = 0;\n isoBandNextXTL[35] = -1;\n isoBandNextYTL[35] = 0;\n isoBandNextOTL[35] = 1;\n isoBandNextXTR[35] = 1;\n isoBandNextYTR[35] = 0;\n isoBandNextOTR[35] = 1;\n\n /* 6-sided cases */\n isoBandNextXRT[153] = 0;\n isoBandNextYRT[153] = 1;\n isoBandNextORT[153] = 1;\n isoBandNextXBL[153] = -1;\n isoBandNextYBL[153] = 0;\n isoBandNextOBL[153] = 0;\n isoBandNextXLB[153] = 0;\n isoBandNextYLB[153] = -1;\n isoBandNextOLB[153] = 0;\n isoBandNextXTR[153] = 1;\n isoBandNextYTR[153] = 0;\n isoBandNextOTR[153] = 1;\n\n isoBandNextXRB[102] = 0;\n isoBandNextYRB[102] = -1;\n isoBandNextORB[102] = 1;\n isoBandNextXBR[102] = 1;\n isoBandNextYBR[102] = 0;\n isoBandNextOBR[102] = 0;\n isoBandNextXLT[102] = 0;\n isoBandNextYLT[102] = 1;\n isoBandNextOLT[102] = 0;\n isoBandNextXTL[102] = -1;\n isoBandNextYTL[102] = 0;\n isoBandNextOTL[102] = 1;\n\n isoBandNextXRT[155] = 0;\n isoBandNextYRT[155] = -1;\n isoBandNextORT[155] = 0;\n isoBandNextXBL[155] = 1;\n isoBandNextYBL[155] = 0;\n isoBandNextOBL[155] = 1;\n isoBandNextXLB[155] = 0;\n isoBandNextYLB[155] = 1;\n isoBandNextOLB[155] = 1;\n isoBandNextXTR[155] = -1;\n isoBandNextYTR[155] = 0;\n isoBandNextOTR[155] = 0;\n\n isoBandNextXRB[103] = 0;\n isoBandNextYRB[103] = 1;\n isoBandNextORB[103] = 0;\n isoBandNextXBR[103] = -1;\n isoBandNextYBR[103] = 0;\n isoBandNextOBR[103] = 1;\n isoBandNextXLT[103] = 0;\n isoBandNextYLT[103] = -1;\n isoBandNextOLT[103] = 1;\n isoBandNextXTL[103] = 1;\n isoBandNextYTL[103] = 0;\n isoBandNextOTL[103] = 0;\n\n /* 7-sided cases */\n isoBandNextXRT[152] = 0;\n isoBandNextYRT[152] = 1;\n isoBandNextORT[152] = 1;\n isoBandNextXBR[152] = -1;\n isoBandNextYBR[152] = 0;\n isoBandNextOBR[152] = 1;\n isoBandNextXBL[152] = -1;\n isoBandNextYBL[152] = 0;\n isoBandNextOBL[152] = 0;\n isoBandNextXLB[152] = 0;\n isoBandNextYLB[152] = -1;\n isoBandNextOLB[152] = 0;\n isoBandNextXLT[152] = 0;\n isoBandNextYLT[152] = -1;\n isoBandNextOLT[152] = 1;\n isoBandNextXTR[152] = 1;\n isoBandNextYTR[152] = 0;\n isoBandNextOTR[152] = 1;\n\n isoBandNextXRT[156] = 0;\n isoBandNextYRT[156] = -1;\n isoBandNextORT[156] = 1;\n isoBandNextXBR[156] = 1;\n isoBandNextYBR[156] = 0;\n isoBandNextOBR[156] = 1;\n isoBandNextXBL[156] = -1;\n isoBandNextYBL[156] = 0;\n isoBandNextOBL[156] = 0;\n isoBandNextXLB[156] = 0;\n isoBandNextYLB[156] = -1;\n isoBandNextOLB[156] = 0;\n isoBandNextXLT[156] = 0;\n isoBandNextYLT[156] = 1;\n isoBandNextOLT[156] = 1;\n isoBandNextXTR[156] = -1;\n isoBandNextYTR[156] = 0;\n isoBandNextOTR[156] = 1;\n\n isoBandNextXRT[137] = 0;\n isoBandNextYRT[137] = 1;\n isoBandNextORT[137] = 1;\n isoBandNextXRB[137] = 0;\n isoBandNextYRB[137] = 1;\n isoBandNextORB[137] = 0;\n isoBandNextXBL[137] = -1;\n isoBandNextYBL[137] = 0;\n isoBandNextOBL[137] = 0;\n isoBandNextXLB[137] = 0;\n isoBandNextYLB[137] = -1;\n isoBandNextOLB[137] = 0;\n isoBandNextXTL[137] = 1;\n isoBandNextYTL[137] = 0;\n isoBandNextOTL[137] = 0;\n isoBandNextXTR[137] = 1;\n isoBandNextYTR[137] = 0;\n isoBandNextOTR[137] = 1;\n\n isoBandNextXRT[139] = 0;\n isoBandNextYRT[139] = 1;\n isoBandNextORT[139] = 1;\n isoBandNextXRB[139] = 0;\n isoBandNextYRB[139] = -1;\n isoBandNextORB[139] = 0;\n isoBandNextXBL[139] = 1;\n isoBandNextYBL[139] = 0;\n isoBandNextOBL[139] = 0;\n isoBandNextXLB[139] = 0;\n isoBandNextYLB[139] = 1;\n isoBandNextOLB[139] = 0;\n isoBandNextXTL[139] = -1;\n isoBandNextYTL[139] = 0;\n isoBandNextOTL[139] = 0;\n isoBandNextXTR[139] = 1;\n isoBandNextYTR[139] = 0;\n isoBandNextOTR[139] = 1;\n\n isoBandNextXRT[98] = 0;\n isoBandNextYRT[98] = -1;\n isoBandNextORT[98] = 0;\n isoBandNextXRB[98] = 0;\n isoBandNextYRB[98] = -1;\n isoBandNextORB[98] = 1;\n isoBandNextXBR[98] = 1;\n isoBandNextYBR[98] = 0;\n isoBandNextOBR[98] = 0;\n isoBandNextXBL[98] = 1;\n isoBandNextYBL[98] = 0;\n isoBandNextOBL[98] = 1;\n isoBandNextXLT[98] = 0;\n isoBandNextYLT[98] = 1;\n isoBandNextOLT[98] = 0;\n isoBandNextXTL[98] = -1;\n isoBandNextYTL[98] = 0;\n isoBandNextOTL[98] = 1;\n\n isoBandNextXRT[99] = 0;\n isoBandNextYRT[99] = 1;\n isoBandNextORT[99] = 0;\n isoBandNextXRB[99] = 0;\n isoBandNextYRB[99] = -1;\n isoBandNextORB[99] = 1;\n isoBandNextXBR[99] = 1;\n isoBandNextYBR[99] = 0;\n isoBandNextOBR[99] = 0;\n isoBandNextXBL[99] = -1;\n isoBandNextYBL[99] = 0;\n isoBandNextOBL[99] = 1;\n isoBandNextXLT[99] = 0;\n isoBandNextYLT[99] = -1;\n isoBandNextOLT[99] = 0;\n isoBandNextXTL[99] = 1;\n isoBandNextYTL[99] = 0;\n isoBandNextOTL[99] = 1;\n\n isoBandNextXRB[38] = 0;\n isoBandNextYRB[38] = -1;\n isoBandNextORB[38] = 1;\n isoBandNextXBR[38] = 1;\n isoBandNextYBR[38] = 0;\n isoBandNextOBR[38] = 0;\n isoBandNextXLB[38] = 0;\n isoBandNextYLB[38] = 1;\n isoBandNextOLB[38] = 1;\n isoBandNextXLT[38] = 0;\n isoBandNextYLT[38] = 1;\n isoBandNextOLT[38] = 0;\n isoBandNextXTL[38] = -1;\n isoBandNextYTL[38] = 0;\n isoBandNextOTL[38] = 1;\n isoBandNextXTR[38] = -1;\n isoBandNextYTR[38] = 0;\n isoBandNextOTR[38] = 0;\n\n isoBandNextXRB[39] = 0;\n isoBandNextYRB[39] = 1;\n isoBandNextORB[39] = 1;\n isoBandNextXBR[39] = -1;\n isoBandNextYBR[39] = 0;\n isoBandNextOBR[39] = 0;\n isoBandNextXLB[39] = 0;\n isoBandNextYLB[39] = -1;\n isoBandNextOLB[39] = 1;\n isoBandNextXLT[39] = 0;\n isoBandNextYLT[39] = 1;\n isoBandNextOLT[39] = 0;\n isoBandNextXTL[39] = -1;\n isoBandNextYTL[39] = 0;\n isoBandNextOTL[39] = 1;\n isoBandNextXTR[39] = 1;\n isoBandNextYTR[39] = 0;\n isoBandNextOTR[39] = 0;\n\n\n /*\n Define helper functions for the polygon_table\n */\n\n /* triangle cases */\n var p00 = function (cell) {\n return [[cell.bottomleft, 0], [0, 0], [0, cell.leftbottom]];\n };\n var p01 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0]];\n };\n var p02 = function (cell) {\n return [[cell.topright, 1], [1, 1], [1, cell.righttop]];\n };\n var p03 = function (cell) {\n return [[0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* trapezoid cases */\n var p04 = function (cell) {\n return [[cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.leftbottom], [0, cell.lefttop]];\n };\n var p05 = function (cell) {\n return [[cell.bottomright, 0], [cell.bottomleft, 0], [1, cell.righttop], [1, cell.rightbottom]];\n };\n var p06 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.topleft, 1], [cell.topright, 1]];\n };\n var p07 = function (cell) {\n return [[0, cell.leftbottom], [0, cell.lefttop], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* rectangle cases */\n var p08 = function (cell) {\n return [[0, 0], [0, cell.leftbottom], [1, cell.rightbottom], [1, 0]];\n };\n var p09 = function (cell) {\n return [[1, 0], [cell.bottomright, 0], [cell.topright, 1], [1, 1]];\n };\n var p10 = function (cell) {\n return [[1, 1], [1, cell.righttop], [0, cell.lefttop], [0, 1]];\n };\n var p11 = function (cell) {\n return [[cell.bottomleft, 0], [0, 0], [0, 1], [cell.topleft, 1]];\n };\n var p12 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [0, cell.leftbottom], [0, cell.lefttop]];\n };\n var p13 = function (cell) {\n return [[cell.topleft, 1], [cell.topright, 1], [cell.bottomright, 0], [cell.bottomleft, 0]];\n };\n /* square case */\n var p14 = function () {\n return [[0, 0], [0, 1], [1, 1], [1, 0]];\n };\n /* pentagon cases */\n var p15 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [0, 0], [0, 1], [cell.topleft, 1]];\n };\n /* 1211 || 1011 */\n var p16 = function (cell) {\n return [[cell.topright, 1], [1, 1], [1, 0], [0, 0], [0, cell.leftbottom]];\n };\n /* 2111 || 0111 */\n var p17 = function (cell) {\n return [[1, 0], [cell.bottomright, 0], [0, cell.lefttop], [0, 1], [1, 1]];\n };\n /* 1112 || 1110 */\n var p18 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomleft, 0], [0, 0], [0, 1]];\n };\n /* 1121 || 1101 */\n var p19 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* 1200 || 1022 */\n var p20 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomright, 0], [cell.bottomleft, 0], [cell.topright, 1]];\n };\n /* 0120 || 2102 */\n var p21 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0], [0, cell.leftbottom], [0, cell.lefttop]];\n };\n /* 0012 || 2210 */\n var p22 = function (cell) {\n return [[cell.topright, 1], [cell.bottomleft, 0], [0, 0], [0, cell.leftbottom], [cell.topleft, 1]];\n };\n /* 2001 || 0221 */\n var p23 = function (cell) {\n return [[cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* 1002 || 1220 */\n var p24 = function (cell) {\n return [[1, 1], [1, cell.righttop], [0, cell.leftbottom], [0, cell.lefttop], [cell.topright, 1]];\n };\n /* 2100 || 0122 */\n var p25 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* 0210 || 2012 */\n var p26 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.bottomleft, 0], [0, 0], [0, cell.leftbottom]];\n };\n /* 0021 || 2201 */\n /*hexagon cases */\n var p27 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [0, 0], [0, cell.leftbottom], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* 0211 || 2011 */\n var p28 = function (cell) {\n return [[1, 1], [1, 0], [cell.bottomright, 0], [0, cell.leftbottom], [0, cell.lefttop], [cell.topright, 1]];\n };\n /* 2110 || 0112 */\n var p29 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.lefttop], [0, 1]];\n };\n /* 1102 || 1120 */\n var p30 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.bottomleft, 0], [0, 0], [0, 1], [cell.topleft, 1]];\n };\n /* 1021 || 1201 */\n var p31 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomleft, 0], [0, 0], [0, cell.leftbottom], [cell.topright, 1]];\n };\n /* 2101 || 0121 */\n var p32 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0], [0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* 1012 || 1210 */\n /* 8-sided cases */\n var p33 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.leftbottom], [0, cell.lefttop], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* flipped == 1 state for 0202 and 2020 */\n /* 6-sided cases */\n var p34 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomleft, 0], [0, 0], [0, cell.leftbottom], [cell.topright, 1]];\n };\n /* 0101 with flipped == 1 || 2121 with flipped == 1 */\n var p35 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0], [0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* 1010 with flipped == 1 || 1212 with flipped == 1 */\n /* 7-sided cases */\n var p36 = function (cell) {\n return [[1, 1], [1, cell.righttop], [cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.leftbottom], [0, cell.lefttop], [cell.topright, 1]];\n };\n /* 2120 with flipped == 1 || 0102 with flipped == 1 */\n var p37 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.bottomleft, 0], [0, 0], [0, cell.leftbottom], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* 2021 with flipped == 1 || 0201 with flipped == 1 */\n var p38 = function (cell) {\n return [[1, cell.righttop], [1, cell.rightbottom], [cell.bottomright, 0], [cell.bottomleft, 0], [0, cell.lefttop], [0, 1], [cell.topleft, 1]];\n };\n /* 1202 with flipped == 1 || 1020 with flipped == 1 */\n var p39 = function (cell) {\n return [[1, cell.rightbottom], [1, 0], [cell.bottomright, 0], [0, cell.leftbottom], [0, cell.lefttop], [cell.topleft, 1], [cell.topright, 1]];\n };\n /* 0212 with flipped == 1 || 2010 with flipped == 1 */\n\n\n\n /*\n The lookup tables for edge number given the polygon\n is entered at a specific location\n */\n\n var isoBandEdgeRT = [];\n var isoBandEdgeRB = [];\n var isoBandEdgeBR = [];\n var isoBandEdgeBL = [];\n var isoBandEdgeLB = [];\n var isoBandEdgeLT = [];\n var isoBandEdgeTL = [];\n var isoBandEdgeTR = [];\n\n /* triangle cases */\n isoBandEdgeBL[1] = isoBandEdgeLB[1] = 18;\n isoBandEdgeBL[169] = isoBandEdgeLB[169] = 18;\n isoBandEdgeBR[4] = isoBandEdgeRB[4] = 12;\n isoBandEdgeBR[166] = isoBandEdgeRB[166] = 12;\n isoBandEdgeRT[16] = isoBandEdgeTR[16] = 4;\n isoBandEdgeRT[154] = isoBandEdgeTR[154] = 4;\n isoBandEdgeLT[64] = isoBandEdgeTL[64] = 22;\n isoBandEdgeLT[106] = isoBandEdgeTL[106] = 22;\n\n /* trapezoid cases */\n isoBandEdgeBR[2] = isoBandEdgeLT[2] = 17;\n isoBandEdgeBL[2] = isoBandEdgeLB[2] = 18;\n isoBandEdgeBR[168] = isoBandEdgeLT[168] = 17;\n isoBandEdgeBL[168] = isoBandEdgeLB[168] = 18;\n isoBandEdgeRT[8] = isoBandEdgeBL[8] = 9;\n isoBandEdgeRB[8] = isoBandEdgeBR[8] = 12;\n isoBandEdgeRT[162] = isoBandEdgeBL[162] = 9;\n isoBandEdgeRB[162] = isoBandEdgeBR[162] = 12;\n isoBandEdgeRT[32] = isoBandEdgeTR[32] = 4;\n isoBandEdgeRB[32] = isoBandEdgeTL[32] = 1;\n isoBandEdgeRT[138] = isoBandEdgeTR[138] = 4;\n isoBandEdgeRB[138] = isoBandEdgeTL[138] = 1;\n isoBandEdgeLB[128] = isoBandEdgeTR[128] = 21;\n isoBandEdgeLT[128] = isoBandEdgeTL[128] = 22;\n isoBandEdgeLB[42] = isoBandEdgeTR[42] = 21;\n isoBandEdgeLT[42] = isoBandEdgeTL[42] = 22;\n\n /* rectangle cases */\n isoBandEdgeRB[5] = isoBandEdgeLB[5] = 14;\n isoBandEdgeRB[165] = isoBandEdgeLB[165] = 14;\n isoBandEdgeBR[20] = isoBandEdgeTR[20] = 6;\n isoBandEdgeBR[150] = isoBandEdgeTR[150] = 6;\n isoBandEdgeRT[80] = isoBandEdgeLT[80] = 11;\n isoBandEdgeRT[90] = isoBandEdgeLT[90] = 11;\n isoBandEdgeBL[65] = isoBandEdgeTL[65] = 3;\n isoBandEdgeBL[105] = isoBandEdgeTL[105] = 3;\n isoBandEdgeRT[160] = isoBandEdgeLT[160] = 11;\n isoBandEdgeRB[160] = isoBandEdgeLB[160] = 14;\n isoBandEdgeRT[10] = isoBandEdgeLT[10] = 11;\n isoBandEdgeRB[10] = isoBandEdgeLB[10] = 14;\n isoBandEdgeBR[130] = isoBandEdgeTR[130] = 6;\n isoBandEdgeBL[130] = isoBandEdgeTL[130] = 3;\n isoBandEdgeBR[40] = isoBandEdgeTR[40] = 6;\n isoBandEdgeBL[40] = isoBandEdgeTL[40] = 3;\n\n /* pentagon cases */\n isoBandEdgeRB[101] = isoBandEdgeTL[101] = 1;\n isoBandEdgeRB[69] = isoBandEdgeTL[69] = 1;\n isoBandEdgeLB[149] = isoBandEdgeTR[149] = 21;\n isoBandEdgeLB[21] = isoBandEdgeTR[21] = 21;\n isoBandEdgeBR[86] = isoBandEdgeLT[86] = 17;\n isoBandEdgeBR[84] = isoBandEdgeLT[84] = 17;\n isoBandEdgeRT[89] = isoBandEdgeBL[89] = 9;\n isoBandEdgeRT[81] = isoBandEdgeBL[81] = 9;\n isoBandEdgeRT[96] = isoBandEdgeTL[96] = 0;\n isoBandEdgeRB[96] = isoBandEdgeLT[96] = 15;\n isoBandEdgeRT[74] = isoBandEdgeTL[74] = 0;\n isoBandEdgeRB[74] = isoBandEdgeLT[74] = 15;\n isoBandEdgeRT[24] = isoBandEdgeBR[24] = 8;\n isoBandEdgeBL[24] = isoBandEdgeTR[24] = 7;\n isoBandEdgeRT[146] = isoBandEdgeBR[146] = 8;\n isoBandEdgeBL[146] = isoBandEdgeTR[146] = 7;\n isoBandEdgeRB[6] = isoBandEdgeLT[6] = 15;\n isoBandEdgeBR[6] = isoBandEdgeLB[6] = 16;\n isoBandEdgeRB[164] = isoBandEdgeLT[164] = 15;\n isoBandEdgeBR[164] = isoBandEdgeLB[164] = 16;\n isoBandEdgeBL[129] = isoBandEdgeTR[129] = 7;\n isoBandEdgeLB[129] = isoBandEdgeTL[129] = 20;\n isoBandEdgeBL[41] = isoBandEdgeTR[41] = 7;\n isoBandEdgeLB[41] = isoBandEdgeTL[41] = 20;\n isoBandEdgeBR[66] = isoBandEdgeTL[66] = 2;\n isoBandEdgeBL[66] = isoBandEdgeLT[66] = 19;\n isoBandEdgeBR[104] = isoBandEdgeTL[104] = 2;\n isoBandEdgeBL[104] = isoBandEdgeLT[104] = 19;\n isoBandEdgeRT[144] = isoBandEdgeLB[144] = 10;\n isoBandEdgeLT[144] = isoBandEdgeTR[144] = 23;\n isoBandEdgeRT[26] = isoBandEdgeLB[26] = 10;\n isoBandEdgeLT[26] = isoBandEdgeTR[26] = 23;\n isoBandEdgeRB[36] = isoBandEdgeTR[36] = 5;\n isoBandEdgeBR[36] = isoBandEdgeTL[36] = 2;\n isoBandEdgeRB[134] = isoBandEdgeTR[134] = 5;\n isoBandEdgeBR[134] = isoBandEdgeTL[134] = 2;\n isoBandEdgeRT[9] = isoBandEdgeLB[9] = 10;\n isoBandEdgeRB[9] = isoBandEdgeBL[9] = 13;\n isoBandEdgeRT[161] = isoBandEdgeLB[161] = 10;\n isoBandEdgeRB[161] = isoBandEdgeBL[161] = 13;\n\n /* hexagon cases */\n isoBandEdgeRB[37] = isoBandEdgeTR[37] = 5;\n isoBandEdgeLB[37] = isoBandEdgeTL[37] = 20;\n isoBandEdgeRB[133] = isoBandEdgeTR[133] = 5;\n isoBandEdgeLB[133] = isoBandEdgeTL[133] = 20;\n isoBandEdgeBR[148] = isoBandEdgeLB[148] = 16;\n isoBandEdgeLT[148] = isoBandEdgeTR[148] = 23;\n isoBandEdgeBR[22] = isoBandEdgeLB[22] = 16;\n isoBandEdgeLT[22] = isoBandEdgeTR[22] = 23;\n isoBandEdgeRT[82] = isoBandEdgeBR[82] = 8;\n isoBandEdgeBL[82] = isoBandEdgeLT[82] = 19;\n isoBandEdgeRT[88] = isoBandEdgeBR[88] = 8;\n isoBandEdgeBL[88] = isoBandEdgeLT[88] = 19;\n isoBandEdgeRT[73] = isoBandEdgeTL[73] = 0;\n isoBandEdgeRB[73] = isoBandEdgeBL[73] = 13;\n isoBandEdgeRT[97] = isoBandEdgeTL[97] = 0;\n isoBandEdgeRB[97] = isoBandEdgeBL[97] = 13;\n isoBandEdgeRT[145] = isoBandEdgeBL[145] = 9;\n isoBandEdgeLB[145] = isoBandEdgeTR[145] = 21;\n isoBandEdgeRT[25] = isoBandEdgeBL[25] = 9;\n isoBandEdgeLB[25] = isoBandEdgeTR[25] = 21;\n isoBandEdgeRB[70] = isoBandEdgeTL[70] = 1;\n isoBandEdgeBR[70] = isoBandEdgeLT[70] = 17;\n isoBandEdgeRB[100] = isoBandEdgeTL[100] = 1;\n isoBandEdgeBR[100] = isoBandEdgeLT[100] = 17;\n\n /* 8-sided cases */\n isoBandEdgeRT[34] = isoBandEdgeBL[34] = 9;\n isoBandEdgeRB[34] = isoBandEdgeBR[34] = 12;\n isoBandEdgeLB[34] = isoBandEdgeTR[34] = 21;\n isoBandEdgeLT[34] = isoBandEdgeTL[34] = 22;\n isoBandEdgeRT[136] = isoBandEdgeTR[136] = 4;\n isoBandEdgeRB[136] = isoBandEdgeTL[136] = 1;\n isoBandEdgeBR[136] = isoBandEdgeLT[136] = 17;\n isoBandEdgeBL[136] = isoBandEdgeLB[136] = 18;\n isoBandEdgeRT[35] = isoBandEdgeTR[35] = 4;\n isoBandEdgeRB[35] = isoBandEdgeBR[35] = 12;\n isoBandEdgeBL[35] = isoBandEdgeLB[35] = 18;\n isoBandEdgeLT[35] = isoBandEdgeTL[35] = 22;\n\n /* 6-sided cases */\n isoBandEdgeRT[153] = isoBandEdgeTR[153] = 4;\n isoBandEdgeBL[153] = isoBandEdgeLB[153] = 18;\n isoBandEdgeRB[102] = isoBandEdgeBR[102] = 12;\n isoBandEdgeLT[102] = isoBandEdgeTL[102] = 22;\n isoBandEdgeRT[155] = isoBandEdgeBL[155] = 9;\n isoBandEdgeLB[155] = isoBandEdgeTR[155] = 23;\n isoBandEdgeRB[103] = isoBandEdgeTL[103] = 1;\n isoBandEdgeBR[103] = isoBandEdgeLT[103] = 17;\n\n /* 7-sided cases */\n isoBandEdgeRT[152] = isoBandEdgeTR[152] = 4;\n isoBandEdgeBR[152] = isoBandEdgeLT[152] = 17;\n isoBandEdgeBL[152] = isoBandEdgeLB[152] = 18;\n isoBandEdgeRT[156] = isoBandEdgeBR[156] = 8;\n isoBandEdgeBL[156] = isoBandEdgeLB[156] = 18;\n isoBandEdgeLT[156] = isoBandEdgeTR[156] = 23;\n isoBandEdgeRT[137] = isoBandEdgeTR[137] = 4;\n isoBandEdgeRB[137] = isoBandEdgeTL[137] = 1;\n isoBandEdgeBL[137] = isoBandEdgeLB[137] = 18;\n isoBandEdgeRT[139] = isoBandEdgeTR[139] = 4;\n isoBandEdgeRB[139] = isoBandEdgeBL[139] = 13;\n isoBandEdgeLB[139] = isoBandEdgeTL[139] = 20;\n isoBandEdgeRT[98] = isoBandEdgeBL[98] = 9;\n isoBandEdgeRB[98] = isoBandEdgeBR[98] = 12;\n isoBandEdgeLT[98] = isoBandEdgeTL[98] = 22;\n isoBandEdgeRT[99] = isoBandEdgeTL[99] = 0;\n isoBandEdgeRB[99] = isoBandEdgeBR[99] = 12;\n isoBandEdgeBL[99] = isoBandEdgeLT[99] = 19;\n isoBandEdgeRB[38] = isoBandEdgeBR[38] = 12;\n isoBandEdgeLB[38] = isoBandEdgeTR[38] = 21;\n isoBandEdgeLT[38] = isoBandEdgeTL[38] = 22;\n isoBandEdgeRB[39] = isoBandEdgeTR[39] = 5;\n isoBandEdgeBR[39] = isoBandEdgeLB[39] = 16;\n isoBandEdgeLT[39] = isoBandEdgeTL[39] = 22;\n\n /*\n The lookup tables for all different polygons that\n may appear within a grid cell\n */\n\n var polygon_table = [];\n\n /* triangle cases */\n polygon_table[1] = polygon_table[169] = p00; /* 2221 || 0001 */\n polygon_table[4] = polygon_table[166] = p01; /* 2212 || 0010 */\n polygon_table[16] = polygon_table[154] = p02; /* 2122 || 0100 */\n polygon_table[64] = polygon_table[106] = p03; /* 1222 || 1000 */\n\n /* trapezoid cases */\n polygon_table[168] = polygon_table[2] = p04; /* 2220 || 0002 */\n polygon_table[162] = polygon_table[8] = p05; /* 2202 || 0020 */\n polygon_table[138] = polygon_table[32] = p06; /* 2022 || 0200 */\n polygon_table[42] = polygon_table[128] = p07; /* 0222 || 2000 */\n\n /* rectangle cases */\n polygon_table[5] = polygon_table[165] = p08; /* 0011 || 2211 */\n polygon_table[20] = polygon_table[150] = p09; /* 0110 || 2112 */\n polygon_table[80] = polygon_table[90] = p10; /* 1100 || 1122 */\n polygon_table[65] = polygon_table[105] = p11; /* 1001 || 1221 */\n polygon_table[160] = polygon_table[10] = p12; /* 2200 || 0022 */\n polygon_table[130] = polygon_table[40] = p13; /* 2002 || 0220 */\n\n /* square case */\n polygon_table[85] = p14; /* 1111 */\n\n /* pentagon cases */\n polygon_table[101] = polygon_table[69] = p15; /* 1211 || 1011 */\n polygon_table[149] = polygon_table[21] = p16; /* 2111 || 0111 */\n polygon_table[86] = polygon_table[84] = p17; /* 1112 || 1110 */\n polygon_table[89] = polygon_table[81] = p18; /* 1121 || 1101 */\n polygon_table[96] = polygon_table[74] = p19; /* 1200 || 1022 */\n polygon_table[24] = polygon_table[146] = p20; /* 0120 || 2102 */\n polygon_table[6] = polygon_table[164] = p21; /* 0012 || 2210 */\n polygon_table[129] = polygon_table[41] = p22; /* 2001 || 0221 */\n polygon_table[66] = polygon_table[104] = p23; /* 1002 || 1220 */\n polygon_table[144] = polygon_table[26] = p24; /* 2100 || 0122 */\n polygon_table[36] = polygon_table[134] = p25; /* 0210 || 2012 */\n polygon_table[9] = polygon_table[161] = p26; /* 0021 || 2201 */\n\n /* hexagon cases */\n polygon_table[37] = polygon_table[133] = p27; /* 0211 || 2011 */\n polygon_table[148] = polygon_table[22] = p28; /* 2110 || 0112 */\n polygon_table[82] = polygon_table[88] = p29; /* 1102 || 1120 */\n polygon_table[73] = polygon_table[97] = p30; /* 1021 || 1201 */\n polygon_table[145] = polygon_table[25] = p31; /* 2101 || 0121 */\n polygon_table[70] = polygon_table[100] = p32; /* 1012 || 1210 */\n\n /* 8-sided cases */\n polygon_table[34] = function(c){ return [ p07(c), p05(c) ];}; /* 0202 || 2020 with flipped == 0 */\n polygon_table[35] = p33; /* flipped == 1 state for 0202 and 2020 */\n polygon_table[136] = function(c){ return [ p06(c), p04(c) ];}; /* 2020 || 0202 with flipped == 0 */\n\n /* 6-sided cases */\n polygon_table[153] = function(c){ return [ p02(c), p00(c) ];}; /* 0101 with flipped == 0 || 2121 with flipped == 2 */\n polygon_table[102] = function(c){ return [ p01(c), p03(c) ];}; /* 1010 with flipped == 0 || 1212 with flipped == 2 */\n polygon_table[155] = p34; /* 0101 with flipped == 1 || 2121 with flipped == 1 */\n polygon_table[103] = p35; /* 1010 with flipped == 1 || 1212 with flipped == 1 */\n\n /* 7-sided cases */\n polygon_table[152] = function(c){ return [ p02(c), p04(c) ];}; /* 2120 with flipped == 2 || 0102 with flipped == 0 */\n polygon_table[156] = p36; /* 2120 with flipped == 1 || 0102 with flipped == 1 */\n polygon_table[137] = function(c){ return [ p06(c), p00(c) ];}; /* 2021 with flipped == 2 || 0201 with flipped == 0 */\n polygon_table[139] = p37; /* 2021 with flipped == 1 || 0201 with flipped == 1 */\n polygon_table[98] = function(c){ return [ p05(c), p03(c) ];}; /* 1202 with flipped == 2 || 1020 with flipped == 0 */\n polygon_table[99] = p38; /* 1202 with flipped == 1 || 1020 with flipped == 1 */\n polygon_table[38] = function(c){ return [ p01(c), p07(c) ];}; /* 0212 with flipped == 2 || 2010 with flipped == 0 */\n polygon_table[39] = p39; /* 0212 with flipped == 1 || 2010 with flipped == 1 */\n \n \n /*\n ####################################\n Some small helper functions\n ####################################\n */\n\n /* assume that x1 == 1 && x0 == 0 */\n function interpolateX(y, y0, y1){\n return (y - y0) / (y1 - y0);\n }\n\n function isArray(myArray) {\n return myArray.constructor.toString().indexOf(\"Array\") > -1;\n }\n\n /*\n ####################################\n Below is the actual Marching Squares implementation\n ####################################\n */\n\n function computeBandGrid(data, minV, bandwidth){\n var rows = data.length - 1;\n var cols = data[0].length - 1;\n var BandGrid = { rows: rows, cols: cols, cells: [] };\n\n var maxV = minV + Math.abs(bandwidth);\n\n for(var j = 0; j < rows; ++j){\n BandGrid.cells[j] = [];\n for(var i = 0; i < cols; ++i){\n /* compose the 4-trit corner representation */\n var cval = 0;\n\n var tl = data[j+1][i];\n var tr = data[j+1][i+1];\n var br = data[j][i+1];\n var bl = data[j][i];\n\n if(isNaN(tl) || isNaN(tr) || isNaN(br) || isNaN(bl)){\n continue;\n }\n\n cval |= (tl < minV) ? 0 : (tl > maxV) ? 128 : 64;\n cval |= (tr < minV) ? 0 : (tr > maxV) ? 32 : 16;\n cval |= (br < minV) ? 0 : (br > maxV) ? 8 : 4;\n cval |= (bl < minV) ? 0 : (bl > maxV) ? 2 : 1;\n\n var cval_real = +cval;\n\n /* resolve ambiguity via averaging */\n var flipped = 0;\n if( (cval === 17) /* 0101 */\n || (cval === 18) /* 0102 */\n || (cval === 33) /* 0201 */\n || (cval === 34) /* 0202 */\n || (cval === 38) /* 0212 */\n || (cval === 68) /* 1010 */\n || (cval === 72) /* 1020 */\n || (cval === 98) /* 1202 */\n || (cval === 102) /* 1212 */\n || (cval === 132) /* 2010 */\n || (cval === 136) /* 2020 */\n || (cval === 137) /* 2021 */\n || (cval === 152) /* 2120 */\n || (cval === 153) /* 2121 */\n ){\n var average = (tl + tr + br + bl) / 4;\n /* set flipped state */\n flipped = (average > maxV) ? 2 : (average < minV) ? 0 : 1;\n\n /* adjust cval for flipped cases */\n\n /* 8-sided cases */\n if(cval === 34){\n if(flipped === 1){\n cval = 35;\n } else if(flipped === 0){\n cval = 136;\n }\n } else if(cval === 136){\n if(flipped === 1){\n cval = 35;\n flipped = 4;\n } else if(flipped === 0){\n cval = 34;\n }\n }\n\n /* 6-sided polygon cases */\n else if(cval === 17){\n if(flipped === 1){\n cval = 155;\n flipped = 4;\n } else if(flipped === 0){\n cval = 153;\n }\n } else if(cval === 68){\n if(flipped === 1){\n cval = 103;\n flipped = 4;\n } else if(flipped === 0){\n cval = 102;\n }\n } else if(cval === 153){\n if(flipped === 1)\n cval = 155;\n } else if(cval === 102){\n if(flipped === 1)\n cval = 103;\n }\n\n /* 7-sided polygon cases */\n else if(cval === 152){\n if(flipped < 2){\n cval = 156;\n flipped = 1;\n }\n } else if(cval === 137){\n if(flipped < 2){\n cval = 139;\n flipped = 1;\n }\n } else if(cval === 98){\n if(flipped < 2){\n cval = 99;\n flipped = 1;\n }\n } else if(cval === 38){\n if(flipped < 2){\n cval = 39;\n flipped = 1;\n }\n } else if(cval === 18){\n if(flipped > 0){\n cval = 156;\n flipped = 4;\n } else {\n cval = 152;\n }\n } else if(cval === 33){\n if(flipped > 0){\n cval = 139;\n flipped = 4;\n } else {\n cval = 137;\n }\n } else if(cval === 72){\n if(flipped > 0){\n cval = 99;\n flipped = 4;\n } else {\n cval = 98;\n }\n } else if(cval === 132){\n if(flipped > 0){\n cval = 39;\n flipped = 4;\n } else {\n cval = 38;\n }\n }\n }\n\n /* add cell to BandGrid if it contains at least one polygon-side */\n if((cval != 0) && (cval != 170)){\n var topleft, topright, bottomleft, bottomright,\n righttop, rightbottom, lefttop, leftbottom;\n\n topleft = topright = bottomleft = bottomright = righttop\n = rightbottom = lefttop = leftbottom = 0.5;\n\n var edges = [];\n\n /* do interpolation here */\n /* 1st Triangles */\n if(cval === 1){ /* 0001 */\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 169){ /* 2221 */\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 4){ /* 0010 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = interpolateX(minV, bl, br);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 166){ /* 2212 */\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = 1 - interpolateX(maxV, br, bl);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 16){ /* 0100 */\n righttop = interpolateX(minV, br, tr);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n } else if(cval === 154){ /* 2122 */\n righttop = 1 - interpolateX(maxV, tr, br);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n } else if(cval === 64){ /* 1000 */\n lefttop = interpolateX(minV, bl, tl);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 106){ /* 1222 */\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeLT[cval]);\n }\n /* 2nd Trapezoids */\n else if(cval === 168){ /* 2220 */\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 2){ /* 0002 */\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 162){ /* 2202 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 8){ /* 0020 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 138){ /* 2022 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 32){ /* 0200 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 42){ /* 0222 */\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeLB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 128){ /* 2000 */\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeLB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n }\n\n /* 3rd rectangle cases */\n if(cval === 5){ /* 0011 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 165){ /* 2211 */\n rightbottom = interpolateX(maxV, br, tr);\n leftbottom = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 20){ /* 0110 */\n bottomright = interpolateX(minV, bl, br);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 150){ /* 2112 */\n bottomright = 1 - interpolateX(maxV, br, bl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 80){ /* 1100 */\n righttop = interpolateX(minV, br, tr);\n lefttop = interpolateX(minV, bl, tl);\n edges.push(isoBandEdgeRT[cval]);\n } else if(cval === 90){ /* 1122 */\n righttop = 1 - interpolateX(maxV, tr, br);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n edges.push(isoBandEdgeRT[cval]);\n } else if(cval === 65){ /* 1001 */\n bottomleft = 1 - interpolateX(minV, br, bl);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 105){ /* 1221 */\n bottomleft = interpolateX(maxV, bl, br);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 160){ /* 2200 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 10){ /* 0022 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 130){ /* 2002 */\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 40){ /* 0220 */\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n }\n\n /* 4th single pentagon cases */\n else if(cval === 101){ /* 1211 */\n rightbottom = interpolateX(maxV, br, tr);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 69){ /* 1011 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 149){ /* 2111 */\n leftbottom = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 21){ /* 0111 */\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 86){ /* 1112 */\n bottomright = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 84){ /* 1110 */\n bottomright = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 89){ /* 1121 */\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 81){ /* 1101 */\n righttop = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 96){ /* 1200 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n lefttop = interpolateX(minV, bl, tl);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 74){ /* 1022 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1- interpolateX(maxV, tr, br);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 24){ /* 0120 */\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 146){ /* 2102 */\n righttop = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 6){ /* 0012 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 164){ /* 2210 */\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 129){ /* 2001 */\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeBL[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 41){ /* 0221 */\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeBL[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 66){ /* 1002 */\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 104){ /* 1220 */\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeBL[cval]);\n edges.push(isoBandEdgeTL[cval]);\n } else if(cval === 144){ /* 2100 */\n righttop = interpolateX(minV, br, tr);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 26){ /* 0122 */\n righttop = 1 - interpolateX(maxV, tr, br);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 36){ /* 0210 */\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = interpolateX(minV, bl, br);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 134){ /* 2012 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = 1 - interpolateX(maxV, br, bl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 9){ /* 0021 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 161){ /* 2201 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = interpolateX(maxV, bl, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n }\n\n /* 5th single hexagon cases */\n else if(cval === 37){ /* 0211 */\n rightbottom = interpolateX(maxV, br, tr);\n leftbottom = 1- interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 133){ /* 2011 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n leftbottom = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 148){ /* 2110 */\n bottomright = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 22){ /* 0112 */\n bottomright = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 82){ /* 1102 */\n righttop = interpolateX(minV, br, tr);\n bottomright = 1- interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 88){ /* 1120 */\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 73){ /* 1021 */\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 97){ /* 1201 */\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n } else if(cval === 145){ /* 2101 */\n righttop = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 25){ /* 0121 */\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 70){ /* 1012 */\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = 1 - interpolateX(minV, tr, tl);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n } else if(cval === 100){ /* 1210 */\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = interpolateX(maxV, tl, tr);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n }\n\n /* 8-sided cases */\n else if(cval === 34){ /* 0202 || 2020 with flipped == 0 */\n if(flipped === 0){\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n } else {\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 35){ /* flipped == 1 state for 0202, and 2020 with flipped == 4*/\n if(flipped === 4){\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n } else {\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBL[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 136){ /* 2020 || 0202 with flipped == 0 */\n if(flipped === 0){\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n } else {\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n }\n\n /* 6-sided polygon cases */\n else if(cval === 153){ /* 0101 with flipped == 0 || 2121 with flipped == 2 */\n if(flipped === 0){\n righttop = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n } else {\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 102){ /* 1010 with flipped == 0 || 1212 with flipped == 2 */\n if(flipped === 0){\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = 1 - interpolateX(minV, tr, tl);\n } else {\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 155){ /* 0101 with flipped == 4 || 2121 with flipped == 1 */\n if(flipped === 4){\n righttop = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n } else {\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 103){ /* 1010 with flipped == 4 || 1212 with flipped == 1 */\n if(flipped === 4){\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = 1 - interpolateX(minV, tr, tl);\n } else {\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n }\n\n /* 7-sided polygon cases */\n else if(cval === 152){ /* 2120 with flipped == 2 || 0102 with flipped == 0 */\n if(flipped === 0){\n righttop = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n } else {\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 156){ /* 2120 with flipped == 1 || 0102 with flipped == 4 */\n if(flipped === 4){\n righttop = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topright = interpolateX(minV, tl, tr);\n } else {\n righttop = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topright = 1 - interpolateX(maxV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeBL[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 137){ /* 2021 with flipped == 2 || 0201 with flipped == 0 */\n if(flipped === 0){\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n } else {\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 139){ /* 2021 with flipped == 1 || 0201 with flipped == 4 */\n if(flipped === 4){\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomleft = 1 - interpolateX(minV, br, bl);\n leftbottom = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n } else {\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomleft = interpolateX(maxV, bl, br);\n leftbottom = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n } else if(cval === 98){ /* 1202 with flipped == 2 || 1020 with flipped == 0 */\n if(flipped === 0){\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = 1 - interpolateX(minV, tr, tl);\n } else {\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 99){ /* 1202 with flipped == 1 || 1020 with flipped == 4 */\n if(flipped === 4){\n righttop = 1 - interpolateX(minV, tr, br);\n rightbottom = 1 - interpolateX(maxV, tr, br);\n bottomright = interpolateX(maxV, bl, br);\n bottomleft = interpolateX(minV, bl, br);\n lefttop = interpolateX(minV, bl, tl);\n topleft = 1 - interpolateX(minV, tr, tl);\n } else {\n righttop = interpolateX(maxV, br, tr);\n rightbottom = interpolateX(minV, br, tr);\n bottomright = 1 - interpolateX(minV, br, bl);\n bottomleft = 1 - interpolateX(maxV, br, bl);\n lefttop = 1 - interpolateX(maxV, tl, bl);\n topleft = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRT[cval]);\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBL[cval]);\n } else if(cval === 38){ /* 0212 with flipped == 2 || 2010 with flipped == 0 */\n if(flipped === 0){\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n } else {\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeLB[cval]);\n edges.push(isoBandEdgeLT[cval]);\n } else if(cval === 39){ /* 0212 with flipped == 1 || 2010 with flipped == 4 */\n if(flipped === 4){\n rightbottom = 1 - interpolateX(minV, tr, br);\n bottomright = interpolateX(minV, bl, br);\n leftbottom = interpolateX(minV, bl, tl);\n lefttop = interpolateX(maxV, bl, tl);\n topleft = 1 - interpolateX(maxV, tr, tl);\n topright = 1 - interpolateX(minV, tr, tl);\n } else {\n rightbottom = interpolateX(maxV, br, tr);\n bottomright = 1 - interpolateX(maxV, br, bl);\n leftbottom = 1 - interpolateX(maxV, tl, bl);\n lefttop = 1 - interpolateX(minV, tl, bl);\n topleft = interpolateX(minV, tl, tr);\n topright = interpolateX(maxV, tl, tr);\n }\n edges.push(isoBandEdgeRB[cval]);\n edges.push(isoBandEdgeBR[cval]);\n edges.push(isoBandEdgeLT[cval]);\n }\n\n else if(cval === 85){\n righttop = 1;\n rightbottom = 0;\n bottomright = 1;\n bottomleft = 0;\n leftbottom = 0;\n lefttop = 1;\n topleft = 0;\n topright = 1;\n }\n\n if(topleft < 0 || topleft > 1 || topright < 0 || topright > 1 || righttop < 0 || righttop > 1 || bottomright < 0 || bottomright > 1 || leftbottom < 0 || leftbottom > 1 || lefttop < 0 || lefttop > 1){\n console.log(\"MarchingSquaresJS-isoBands: \" + cval + \" \" + cval_real + \" \" + tl + \",\" + tr + \",\" + br + \",\" + bl + \" \" + flipped + \" \" + topleft + \" \" + topright + \" \" + righttop + \" \" + rightbottom + \" \" + bottomright + \" \" + bottomleft + \" \" + leftbottom + \" \" + lefttop);\n }\n\n BandGrid.cells[j][i] = {\n cval: cval,\n cval_real: cval_real,\n flipped: flipped,\n topleft: topleft,\n topright: topright,\n righttop: righttop,\n rightbottom: rightbottom,\n bottomright: bottomright,\n bottomleft: bottomleft,\n leftbottom: leftbottom,\n lefttop: lefttop,\n edges: edges\n };\n }\n }\n }\n\n return BandGrid;\n }\n\n function BandGrid2AreaPaths(grid){\n var areas = [];\n var rows = grid.rows;\n var cols = grid.cols;\n var currentPolygon = [];\n\n for(var j = 0; j < rows; j++){\n for(var i = 0; i < cols; i++){\n if((typeof grid.cells[j][i] !== 'undefined') && (grid.cells[j][i].edges.length > 0)){\n /* trace back polygon path starting from this cell */\n\n var cell = grid.cells[j][i];\n\n /* get start coordinates */\n\n var prev = getStartXY(cell),\n next = null,\n p = i,\n q = j;\n\n if(prev !== null){\n currentPolygon.push([ prev.p[0] + p, prev.p[1] + q ]);\n //console.log(cell);\n //console.log(\"coords: \" + (prev.p[0] + p) + \" \" + (prev.p[1] + q));\n }\n\n do{\n //console.log(p + \",\" + q);\n //console.log(grid.cells[q][p]);\n //console.log(grid.cells[q][p].edges);\n //console.log(\"from : \" + prev.x + \" \" + prev.y + \" \" + prev.o);\n\n next = getExitXY(grid.cells[q][p], prev.x, prev.y, prev.o);\n if(next !== null){\n //console.log(\"coords: \" + (next.p[0] + p) + \" \" + (next.p[1] + q));\n currentPolygon.push([ next.p[0] + p, next.p[1] + q ]);\n p += next.x;\n q += next.y;\n prev = next;\n } else {\n //console.log(\"getExitXY() returned null!\");\n break;\n }\n //console.log(\"to : \" + next.x + \" \" + next.y + \" \" + next.o);\n /* special case, where we've reached the grid boundaries */\n if((q < 0) || (q >= rows) || (p < 0) || (p >= cols) || (typeof grid.cells[q][p] === 'undefined')){\n /* to create a closed path, we need to trace our way\n arround the missing data, until we find an entry\n point again\n */\n\n /* set back coordinates of current cell */\n p -= next.x;\n q -= next.y;\n\n //console.log(\"reached boundary at \" + p + \" \" + q);\n\n var missing = traceOutOfGridPath(grid, p, q, next.x, next.y, next.o);\n if(missing !== null){\n missing.path.forEach(function(pp){\n //console.log(\"coords: \" + (pp[0]) + \" \" + (pp[1]));\n currentPolygon.push(pp);\n });\n p = missing.i;\n q = missing.j;\n prev = missing;\n } else {\n break;\n }\n //console.log(grid.cells[q][p]);\n }\n } while( (typeof grid.cells[q][p] !== 'undefined')\n && (grid.cells[q][p].edges.length > 0));\n\n areas.push(currentPolygon);\n //console.log(\"next polygon\");\n //console.log(currentPolygon);\n currentPolygon = [];\n if(grid.cells[j][i].edges.length > 0)\n i--;\n }\n }\n }\n return areas;\n }\n\n function traceOutOfGridPath(grid, i, j, d_x, d_y, d_o){\n var cell = grid.cells[j][i];\n var cval = cell.cval_real;\n var p = i + d_x,\n q = j + d_y;\n var path = [];\n var closed = false;\n\n while(!closed){\n //console.log(\"processing cell \" + p + \",\" + q + \" \" + d_x + \" \" + d_y + \" \" + d_o);\n if((typeof grid.cells[q] === 'undefined') || (typeof grid.cells[q][p] === 'undefined')){\n //console.log(\"which is undefined\");\n /* we can't move on, so we have to change direction to proceed further */\n\n /* go back to previous cell */\n q -= d_y;\n p -= d_x;\n cell = grid.cells[q][p];\n cval = cell.cval_real;\n\n /* check where we've left defined cells of the grid... */\n if(d_y === -1){ /* we came from top */\n if(d_o === 0){ /* exit left */\n if(cval & Node3){ /* lower left node is within range, so we move left */\n path.push([p, q]);\n d_x = -1;\n d_y = 0;\n d_o = 0;\n } else if(cval & Node2){ /* lower right node is within range, so we move right */\n path.push([p + 1, q]);\n d_x = 1;\n d_y = 0;\n d_o = 0;\n } else { /* close the path */\n path.push([p + cell.bottomright, q]);\n d_x = 0;\n d_y = 1;\n d_o = 1;\n closed = true;\n break;\n }\n } else {\n if(cval & Node3){\n path.push([p, q]);\n d_x = -1;\n d_y = 0;\n d_o = 0;\n } else if(cval & Node2){\n path.push([p + cell.bottomright, q]);\n d_x = 0;\n d_y = 1;\n d_o = 1;\n closed = true;\n break;\n } else {\n path.push([p + cell.bottomleft, q]);\n d_x = 0;\n d_y = 1;\n d_o = 0;\n closed = true;\n break;\n }\n }\n } else if(d_y === 1){ /* we came from bottom */\n //console.log(\"we came from bottom and hit a non-existing cell \" + (p + d_x) + \",\" + (q + d_y) + \"!\");\n if(d_o === 0){ /* exit left */\n if(cval & Node1){ /* top right node is within range, so we move right */\n path.push([p+1,q+1]);\n d_x = 1;\n d_y = 0;\n d_o = 1;\n } else if(!(cval & Node0)){ /* found entry within same cell */\n path.push([p + cell.topright, q + 1]);\n d_x = 0;\n d_y = -1;\n d_o = 1;\n closed = true;\n //console.log(\"found entry from bottom at \" + p + \",\" + q);\n break;\n } else {\n path.push([p + cell.topleft, q + 1]);\n d_x = 0;\n d_y = -1;\n d_o = 0;\n closed = true;\n break;\n }\n } else {\n if(cval & Node1){\n path.push([p+1, q+1]);\n d_x = 1;\n d_y = 0;\n d_o = 1;\n } else { /* move right */\n path.push([p+1, q+1]);\n d_x = 1;\n d_y = 0;\n d_o = 1;\n //console.log(\"wtf\");\n //break;\n }\n }\n } else if(d_x === -1){ /* we came from right */\n //console.log(\"we came from right and hit a non-existing cell at \" + (p + d_x) + \",\" + (q + d_y) + \"!\");\n if(d_o === 0){\n //console.log(\"continue at bottom\");\n if(cval & Node0){\n path.push([p,q+1]);\n d_x = 0;\n d_y = 1;\n d_o = 0;\n //console.log(\"moving upwards to \" + (p + d_x) + \",\" + (q + d_y) + \"!\");\n } else if(!(cval & Node3)){ /* there has to be an entry into the regular grid again! */\n //console.log(\"exiting top\");\n path.push([p, q + cell.lefttop]);\n d_x = 1;\n d_y = 0;\n d_o = 1;\n closed = true;\n break;\n } else {\n //console.log(\"exiting bottom\");\n path.push([p, q + cell.leftbottom]);\n d_x = 1;\n d_y = 0;\n d_o = 0;\n closed = true;\n break;\n }\n } else {\n //console.log(\"continue at top\");\n if(cval & Node0){\n path.push([p,q+1]);\n d_x = 0;\n d_y = 1;\n d_o = 0;\n //console.log(\"moving upwards to \" + (p + d_x) + \",\" + (q + d_y) + \"!\");\n } else { /* */\n console.log(\"MarchingSquaresJS-isoBands: wtf\");\n break;\n }\n }\n } else if(d_x === 1){ /* we came from left */\n //console.log(\"we came from left and hit a non-existing cell \" + (p + d_x) + \",\" + (q + d_y) + \"!\");\n if(d_o === 0){ /* exit bottom */\n if(cval & Node2){\n path.push([p+1,q]);\n d_x = 0;\n d_y = -1;\n d_o = 1;\n } else {\n path.push([p+1,q+cell.rightbottom]);\n d_x = -1;\n d_y = 0;\n d_o = 0;\n closed = true;\n break;\n }\n } else { /* exit top */\n if(cval & Node2){\n path.push([p+1,q]);\n d_x = 0;\n d_y = -1;\n d_o = 1;\n } else if(!(cval & Node1)){\n path.push([p + 1, q + cell.rightbottom]);\n d_x = -1;\n d_y = 0;\n d_o = 0;\n closed = true;\n break;\n } else {\n path.push([p+1,q+cell.righttop]);\n d_x = -1;\n d_y = 0;\n d_o = 1;\n break;\n }\n }\n } else { /* we came from the same cell */\n console.log(\"MarchingSquaresJS-isoBands: we came from nowhere!\");\n break;\n }\n\n } else { /* try to find an entry into the regular grid again! */\n cell = grid.cells[q][p];\n cval = cell.cval_real;\n //console.log(\"which is defined\");\n\n if(d_x === -1){\n if(d_o === 0){\n /* try to go downwards */\n if((typeof grid.cells[q - 1] !== 'undefined') && (typeof grid.cells[q - 1][p] !== 'undefined')){\n d_x = 0;\n d_y = -1;\n d_o = 1;\n } else if(cval & Node3){ /* proceed searching in x-direction */\n //console.log(\"proceeding in x-direction!\");\n path.push([p, q]);\n } else { /* we must have found an entry into the regular grid */\n path.push([p + cell.bottomright, q]);\n d_x = 0;\n d_y = 1;\n d_o = 1;\n closed = true;\n //console.log(\"found entry from bottom at \" + p + \",\" + q);\n break;\n }\n } else {\n if(cval & Node0) { /* proceed searchin in x-direction */\n console.log(\"MarchingSquaresJS-isoBands: proceeding in x-direction!\");\n } else { /* we must have found an entry into the regular grid */\n console.log(\"MarchingSquaresJS-isoBands: found entry from top at \" + p + \",\" + q);\n break;\n }\n }\n } else if(d_x === 1){\n if(d_o === 0){\n console.log(\"MarchingSquaresJS-isoBands: wtf\");\n break;\n } else {\n /* try to go upwards */\n if((typeof grid.cells[q+1] !== 'undefined') && (typeof grid.cells[q+1][p] !== 'undefined')){\n d_x = 0;\n d_y = 1;\n d_o = 0;\n } else if(cval & Node1){\n path.push([p+1,q+1]);\n d_x = 1;\n d_y = 0;\n d_o = 1;\n } else { /* found an entry point into regular grid! */\n path.push([p+cell.topleft, q + 1]);\n d_x = 0;\n d_y = -1;\n d_o = 0;\n closed = true;\n //console.log(\"found entry from bottom at \" + p + \",\" + q);\n break;\n }\n }\n } else if(d_y === -1){\n if(d_o === 1){\n /* try to go right */\n if(typeof grid.cells[q][p+1] !== 'undefined'){\n d_x = 1;\n d_y = 0;\n d_o = 1;\n } else if(cval & Node2){\n path.push([p+1,q]);\n d_x = 0;\n d_y = -1;\n d_o = 1;\n } else { /* found entry into regular grid! */\n path.push([p+1, q + cell.righttop]);\n d_x = -1;\n d_y = 0;\n d_o = 1;\n closed = true;\n //console.log(\"found entry from top at \" + p + \",\" + q);\n break;\n }\n } else {\n console.log(\"MarchingSquaresJS-isoBands: wtf\");\n break;\n }\n } else if(d_y === 1){\n if(d_o === 0){\n //console.log(\"we came from bottom left and proceed to the left\");\n /* try to go left */\n if(typeof grid.cells[q][p - 1] !== 'undefined'){\n d_x = -1;\n d_y = 0;\n d_o = 0;\n } else if(cval & Node0){\n path.push([p,q+1]);\n d_x = 0;\n d_y = 1;\n d_o = 0;\n } else { /* found an entry point into regular grid! */\n path.push([p, q + cell.leftbottom]);\n d_x = 1;\n d_y = 0;\n d_o = 0;\n closed = true;\n //console.log(\"found entry from bottom at \" + p + \",\" + q);\n break;\n }\n } else {\n //console.log(\"we came from bottom right and proceed to the right\");\n console.log(\"MarchingSquaresJS-isoBands: wtf\");\n break;\n }\n } else {\n console.log(\"MarchingSquaresJS-isoBands: where did we came from???\");\n break;\n }\n\n }\n\n p += d_x;\n q += d_y;\n //console.log(\"going on to \" + p + \",\" + q + \" via \" + d_x + \" \" + d_y + \" \" + d_o);\n\n if((p === i) && (q === j)){ /* bail out, once we've closed a circle path */\n break;\n }\n\n }\n\n //console.log(\"exit with \" + p + \",\" + q + \" \" + d_x + \" \" + d_y + \" \" + d_o);\n return { path: path, i: p, j: q, x: d_x, y: d_y, o: d_o };\n }\n\n function deleteEdge(cell, edgeIdx){\n delete cell.edges[edgeIdx];\n for(var k = edgeIdx + 1; k < cell.edges.length; k++){\n cell.edges[k-1] = cell.edges[k];\n }\n cell.edges.pop();\n }\n\n function getStartXY(cell){\n\n if(cell.edges.length > 0){\n var e = cell.edges[cell.edges.length - 1];\n //console.log(\"starting with edge \" + e);\n var cval = cell.cval_real;\n switch(e){\n case 0: if(cval & Node1){ /* node 1 within range */\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n } else { /* node 1 below or above threshold */\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n }\n case 1: if(cval & Node2){\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n } else {\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n }\n case 2: if(cval & Node2){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n }\n case 3: if(cval & Node3){\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n } else {\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n }\n case 4: if(cval & Node1){\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n } else {\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n }\n case 5: if(cval & Node2){\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n } else {\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n }\n case 6: if(cval & Node2){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n }\n case 7: if(cval & Node3){\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n } else {\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n }\n case 8: if(cval & Node2){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n }\n case 9: if(cval & Node3){\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n } else {\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n }\n case 10: if(cval & Node3){\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n } else {\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n }\n case 11: if(cval & Node0){\n return {p: [1, cell.righttop], x: -1, y: 0, o: 1};\n } else {\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n }\n case 12: if(cval & Node2){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n }\n case 13: if(cval & Node3){\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n } else {\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n }\n case 14: if(cval & Node3){\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n } else {\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n }\n case 15: if(cval & Node0){\n return {p: [1, cell.rightbottom], x: -1, y: 0, o: 0};\n } else {\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n }\n case 16: if(cval & Node2){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n }\n case 17: if(cval & Node0){\n return {p: [cell.bottomright, 0], x: 0, y: 1, o: 1};\n } else {\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n }\n case 18: if(cval & Node3){\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n } else {\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n }\n case 19: if(cval & Node0){\n return {p: [cell.bottomleft, 0], x: 0, y: 1, o: 0};\n } else {\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n }\n case 20: if(cval & Node0){\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n } else {\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n }\n case 21: if(cval & Node1){\n return {p: [0, cell.leftbottom], x: 1, y: 0, o: 0};\n } else {\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n }\n case 22: if(cval & Node0){\n return {p: [cell.topleft, 1], x: 0, y: -1, o: 0};\n } else {\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n }\n case 23: if(cval & Node1){\n return {p: [0, cell.lefttop], x: 1, y: 0, o: 1};\n } else {\n return {p: [cell.topright, 1], x: 0, y: -1, o: 1};\n }\n default: console.log(\"MarchingSquaresJS-isoBands: edge index out of range!\");\n console.log(cell);\n break;\n }\n }\n\n return null;\n }\n\n function getExitXY(cell, x, y, o){\n\n var e, id_x, d_x, d_y, cval = cell.cval;\n var d_o;\n\n switch(x){\n case -1: switch(o){\n case 0: e = isoBandEdgeRB[cval];\n d_x = isoBandNextXRB[cval];\n d_y = isoBandNextYRB[cval];\n d_o = isoBandNextORB[cval];\n break;\n default: e = isoBandEdgeRT[cval];\n d_x = isoBandNextXRT[cval];\n d_y = isoBandNextYRT[cval];\n d_o = isoBandNextORT[cval];\n break;\n }\n break;\n case 1: switch(o){\n case 0: e = isoBandEdgeLB[cval];\n d_x = isoBandNextXLB[cval];\n d_y = isoBandNextYLB[cval];\n d_o = isoBandNextOLB[cval];\n break;\n default: e = isoBandEdgeLT[cval];\n d_x = isoBandNextXLT[cval];\n d_y = isoBandNextYLT[cval];\n d_o = isoBandNextOLT[cval];\n break;\n }\n break;\n default: switch(y){\n case -1: switch(o){\n case 0: e = isoBandEdgeTL[cval];\n d_x = isoBandNextXTL[cval];\n d_y = isoBandNextYTL[cval];\n d_o = isoBandNextOTL[cval];\n break;\n default: e = isoBandEdgeTR[cval];\n d_x = isoBandNextXTR[cval];\n d_y = isoBandNextYTR[cval];\n d_o = isoBandNextOTR[cval];\n break;\n }\n break;\n case 1: switch(o){\n case 0: e = isoBandEdgeBL[cval];\n d_x = isoBandNextXBL[cval];\n d_y = isoBandNextYBL[cval];\n d_o = isoBandNextOBL[cval];\n break;\n default: e = isoBandEdgeBR[cval];\n d_x = isoBandNextXBR[cval];\n d_y = isoBandNextYBR[cval];\n d_o = isoBandNextOBR[cval];\n break;\n }\n break;\n default: break;\n }\n break;\n }\n\n id_x = cell.edges.indexOf(e);\n if(typeof cell.edges[id_x] !== 'undefined'){\n deleteEdge(cell, id_x);\n } else {\n //console.log(\"wrong edges...\");\n //console.log(x + \" \" + y + \" \" + o);\n //console.log(cell);\n return null;\n }\n\n cval = cell.cval_real;\n\n switch(e){\n case 0: if(cval & Node1){ /* node 1 within range */\n x = cell.topleft;\n y = 1;\n } else { /* node 1 below or above threshold */\n x = 1;\n y = cell.righttop;\n }\n break;\n case 1: if(cval & Node2){\n x = 1;\n y = cell.rightbottom;\n } else {\n x = cell.topleft;\n y = 1;\n }\n break;\n case 2: if(cval & Node2){\n x = cell.topleft;\n y = 1;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 3: if(cval & Node3){\n x = cell.bottomleft;\n y = 0;\n } else {\n x = cell.topleft;\n y = 1;\n }\n break;\n case 4: if(cval & Node1){\n x = cell.topright;\n y = 1;\n } else {\n x = 1;\n y = cell.righttop;\n }\n break;\n case 5: if(cval & Node2){\n x = 1;\n y = cell.rightbottom;\n } else {\n x = cell.topright;\n y = 1;\n }\n break;\n case 6: if(cval & Node2){\n x = cell.topright;\n y = 1;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 7: if(cval & Node3){\n x = cell.bottomleft;\n y = 0;\n } else {\n x = cell.topright;\n y = 1;\n }\n break;\n case 8: if(cval & Node2){\n x = 1;\n y = cell.righttop;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 9: if(cval & Node3){\n x = cell.bottomleft;\n y = 0;\n } else {\n x = 1;\n y = cell.righttop;\n }\n break;\n case 10: if(cval & Node3){\n x = 1;\n y = cell.righttop;\n } else {\n x = 0;\n y = cell.leftbottom;\n }\n break;\n case 11: if(cval & Node0){\n x = 0;\n y = cell.lefttop;\n } else {\n x = 1;\n y = cell.righttop;\n }\n break;\n case 12: if(cval & Node2){\n x = 1;\n y = cell.rightbottom;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 13: if(cval & Node3){\n x = cell.bottomleft;\n y = 0;\n } else {\n x = 1;\n y = cell.rightbottom;\n }\n break;\n case 14: if(cval & Node3){\n x = 1;\n y = cell.rightbottom;\n } else {\n x = 0;\n y = cell.leftbottom;\n }\n break;\n case 15: if(cval & Node0){\n x = 0;\n y = cell.lefttop;\n } else {\n x = 1;\n y = cell.rightbottom;\n }\n break;\n case 16: if(cval & Node2){\n x = 0;\n y = cell.leftbottom;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 17: if(cval & Node0){\n x = 0;\n y = cell.lefttop;\n } else {\n x = cell.bottomright;\n y = 0;\n }\n break;\n case 18: if(cval & Node3){\n x = cell.bottomleft;\n y = 0;\n } else {\n x = 0;\n y = cell.leftbottom;\n }\n break;\n case 19: if(cval & Node0){\n x = 0;\n y = cell.lefttop;\n } else {\n x = cell.bottomleft;\n y = 0;\n }\n break;\n case 20: if(cval & Node0){\n x = 0;\n y = cell.leftbottom;\n } else {\n x = cell.topleft;\n y = 1;\n }\n break;\n case 21: if(cval & Node1){\n x = cell.topright;\n y = 1;\n } else {\n x = 0;\n y = cell.leftbottom;\n }\n break;\n case 22: if(cval & Node0){\n x = 0;\n y = cell.lefttop;\n } else {\n x = cell.topleft;\n y = 1;\n }\n break;\n case 23: if(cval & Node1){\n x = cell.topright;\n y = 1;\n } else {\n x = 0;\n y = cell.lefttop;\n }\n break;\n default: console.log(\"MarchingSquaresJS-isoBands: edge index out of range!\");\n console.log(cell);\n return null;\n }\n\n if((typeof x === 'undefined') || (typeof y === 'undefined') ||\n (typeof d_x === 'undefined') || (typeof d_y === 'undefined') ||\n (typeof d_o === 'undefined')){\n console.log(\"MarchingSquaresJS-isoBands: undefined value!\");\n console.log(cell);\n console.log(x + \" \" + y + \" \" + d_x + \" \" + d_y + \" \" + d_o);\n }\n return {p: [x, y], x: d_x, y: d_y, o: d_o};\n }\n\n function BandGrid2Areas(grid){\n var areas = [];\n var area_idx = 0;\n\n grid.cells.forEach(function(g, j){\n g.forEach(function(gg, i){\n if(typeof gg !== 'undefined'){\n var a = polygon_table[gg.cval](gg);\n if((typeof a === 'object') && isArray(a)){\n if((typeof a[0] === 'object') && isArray(a[0])){\n if((typeof a[0][0] === 'object') && isArray(a[0][0])){\n a.forEach(function(aa){\n aa.forEach(function(aaa){\n aaa[0] += i;\n aaa[1] += j;\n });\n areas[area_idx++] = aa;\n });\n } else {\n a.forEach(function(aa){\n aa[0] += i;\n aa[1] += j;\n });\n areas[area_idx++] = a;\n }\n } else {\n console.log(\"MarchingSquaresJS-isoBands: bandcell polygon with malformed coordinates\");\n }\n } else {\n console.log(\"MarchingSquaresJS-isoBands: bandcell polygon with null coordinates\");\n }\n }\n });\n });\n\n return areas;\n }\n\n return isoBands;\n\n}));\n","var polygon = require('@turf/helpers').polygon;\nvar earcut = require('earcut');\n\n\n/**\n * Tesselates a {@link Feature} into a {@link FeatureCollection} of triangles\n * using [earcut](https://github.com/mapbox/earcut).\n *\n * @name tesselate\n * @param {Feature} poly the polygon to tesselate\n * @returns {FeatureCollection} a geometrycollection feature\n * @example\n * var poly = turf.polygon([[[11, 0], [22, 4], [31, 0], [31, 11], [21, 15], [11, 11], [11, 0]]]);\n * var triangles = turf.tesselate(poly);\n *\n * //addToMap\n * var addToMap = [poly, triangles]\n */\nmodule.exports = function (poly) {\n if (!poly.geometry || (poly.geometry.type !== 'Polygon' && poly.geometry.type !== 'MultiPolygon')) {\n throw new Error('input must be a Polygon or MultiPolygon');\n }\n\n var fc = {type: 'FeatureCollection', features: []};\n\n if (poly.geometry.type === 'Polygon') {\n fc.features = processPolygon(poly.geometry.coordinates);\n } else {\n poly.geometry.coordinates.forEach(function (coordinates) {\n fc.features = fc.features.concat(processPolygon(coordinates));\n });\n }\n\n return fc;\n};\n\nfunction processPolygon(coordinates) {\n var data = flattenCoords(coordinates);\n var dim = 2;\n var result = earcut(data.vertices, data.holes, dim);\n\n var features = [];\n var vertices = [];\n\n result.forEach(function (vert, i) {\n var index = result[i];\n vertices.push([data.vertices[index * dim], data.vertices[index * dim + 1]]);\n });\n\n for (var i = 0; i < vertices.length; i += 3) {\n var coords = vertices.slice(i, i + 3);\n coords.push(vertices[i]);\n features.push(polygon([coords]));\n }\n\n return features;\n}\n\nfunction flattenCoords(data) {\n var dim = data[0][0].length,\n result = {vertices: [], holes: [], dimensions: dim},\n holeIndex = 0;\n\n for (var i = 0; i < data.length; i++) {\n for (var j = 0; j < data[i].length; j++) {\n for (var d = 0; d < dim; d++) result.vertices.push(data[i][j][d]);\n }\n if (i > 0) {\n holeIndex += data[i - 1].length;\n result.holes.push(holeIndex);\n }\n }\n\n return result;\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('button',{ref:\"button\",staticClass:\"btn btn-default\",class:{active: _vm.active},attrs:{\"title\":_vm.title,\"disabled\":_vm.disabled},on:{\"click\":_vm.onClick}},[_vm._t(\"default\")],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./ToggleButton.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!./ToggleButton.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ToggleButton.vue?vue&type=template&id=73ce89ea&lang=html&\"\nimport script from \"./ToggleButton.vue?vue&type=script&lang=js&\"\nexport * from \"./ToggleButton.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ToggleButton.vue?vue&type=style&index=0&lang=css&\"\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 meta = require('@turf/meta');\nvar rbush = require('geojson-rbush');\nvar helpers = require('@turf/helpers');\nvar getCoords = require('@turf/invariant').getCoords;\nvar lineSegment = require('@turf/line-segment');\nvar point = helpers.point;\nvar featureEach = meta.featureEach;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes any LineString or Polygon GeoJSON and returns the intersecting point(s).\n *\n * @name lineIntersect\n * @param {Geometry|FeatureCollection|Feature} line1 any LineString or Polygon\n * @param {Geometry|FeatureCollection|Feature} line2 any LineString or Polygon\n * @returns {FeatureCollection} point(s) that intersect both\n * @example\n * var line1 = turf.lineString([[126, -11], [129, -21]]);\n * var line2 = turf.lineString([[123, -18], [131, -14]]);\n * var intersects = turf.lineIntersect(line1, line2);\n *\n * //addToMap\n * var addToMap = [line1, line2, intersects]\n */\nmodule.exports = function (line1, line2) {\n var unique = {};\n var results = [];\n\n // First, normalize geometries to features\n // Then, handle simple 2-vertex segments\n if (line1.type === 'LineString') line1 = helpers.feature(line1);\n if (line2.type === 'LineString') line2 = helpers.feature(line2);\n if (line1.type === 'Feature' &&\n line2.type === 'Feature' &&\n line1.geometry.type === 'LineString' &&\n line2.geometry.type === 'LineString' &&\n line1.geometry.coordinates.length === 2 &&\n line2.geometry.coordinates.length === 2) {\n var intersect = intersects(line1, line2);\n if (intersect) results.push(intersect);\n return featureCollection(results);\n }\n\n // Handles complex GeoJSON Geometries\n var tree = rbush();\n tree.load(lineSegment(line2));\n featureEach(lineSegment(line1), function (segment) {\n featureEach(tree.search(segment), function (match) {\n var intersect = intersects(segment, match);\n if (intersect) {\n // prevent duplicate points https://github.com/Turfjs/turf/issues/688\n var key = getCoords(intersect).join(',');\n if (!unique[key]) {\n unique[key] = true;\n results.push(intersect);\n }\n }\n });\n });\n return featureCollection(results);\n};\n\n/**\n * Find a point that intersects LineStrings with two coordinates each\n *\n * @private\n * @param {Feature} line1 GeoJSON LineString (Must only contain 2 coordinates)\n * @param {Feature} line2 GeoJSON LineString (Must only contain 2 coordinates)\n * @returns {Feature} intersecting GeoJSON Point\n */\nfunction intersects(line1, line2) {\n var coords1 = getCoords(line1);\n var coords2 = getCoords(line2);\n if (coords1.length !== 2) {\n throw new Error(' line1 must only contain 2 coordinates');\n }\n if (coords2.length !== 2) {\n throw new Error(' line2 must only contain 2 coordinates');\n }\n var x1 = coords1[0][0];\n var y1 = coords1[0][1];\n var x2 = coords1[1][0];\n var y2 = coords1[1][1];\n var x3 = coords2[0][0];\n var y3 = coords2[0][1];\n var x4 = coords2[1][0];\n var y4 = coords2[1][1];\n var denom = ((y4 - y3) * (x2 - x1)) - ((x4 - x3) * (y2 - y1));\n var numeA = ((x4 - x3) * (y1 - y3)) - ((y4 - y3) * (x1 - x3));\n var numeB = ((x2 - x1) * (y1 - y3)) - ((y2 - y1) * (x1 - x3));\n\n if (denom === 0) {\n if (numeA === 0 && numeB === 0) {\n return null;\n }\n return null;\n }\n\n var uA = numeA / denom;\n var uB = numeB / denom;\n\n if (uA >= 0 && uA <= 1 && uB >= 0 && uB <= 1) {\n var x = x1 + (uA * (x2 - x1));\n var y = y1 + (uA * (y2 - y1));\n return point([x, y]);\n }\n return null;\n}\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SimpleTableSortingButton.vue?vue&type=style&index=0&id=6c9a549e&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SimpleTableSortingButton.vue?vue&type=style&index=0&id=6c9a549e&lang=scss&scoped=true&\"","/**\n * Unwrap a coordinate from a Point Feature, Geometry or a single coordinate.\n *\n * @param {Array|Geometry|Feature} obj any value\n * @returns {Array} coordinates\n */\nfunction getCoord(obj) {\n if (!obj) throw new Error('No obj passed');\n\n var coordinates = getCoords(obj);\n\n // getCoord() must contain at least two numbers (Point)\n if (coordinates.length > 1 &&\n typeof coordinates[0] === 'number' &&\n typeof coordinates[1] === 'number') {\n return coordinates;\n } else {\n throw new Error('Coordinate is not a valid Point');\n }\n}\n\n/**\n * Unwrap coordinates from a Feature, Geometry Object or an Array of numbers\n *\n * @param {Array|Geometry|Feature} obj any value\n * @returns {Array} coordinates\n */\nfunction getCoords(obj) {\n if (!obj) throw new Error('No obj passed');\n var coordinates;\n\n // Array of numbers\n if (obj.length) {\n coordinates = obj;\n\n // Geometry Object\n } else if (obj.coordinates) {\n coordinates = obj.coordinates;\n\n // Feature\n } else if (obj.geometry && obj.geometry.coordinates) {\n coordinates = obj.geometry.coordinates;\n }\n // Checks if coordinates contains a number\n if (coordinates) {\n containsNumber(coordinates);\n return coordinates;\n }\n throw new Error('No valid coordinates');\n}\n\n/**\n * Checks if coordinates contains a number\n *\n * @private\n * @param {Array} coordinates GeoJSON Coordinates\n * @returns {boolean} true if Array contains a number\n */\nfunction containsNumber(coordinates) {\n if (coordinates.length > 1 &&\n typeof coordinates[0] === 'number' &&\n typeof coordinates[1] === 'number') {\n return true;\n }\n if (coordinates[0].length) {\n return containsNumber(coordinates[0]);\n }\n throw new Error('coordinates must only contain numbers');\n}\n\n/**\n * Enforce expectations about types of GeoJSON objects for Turf.\n *\n * @alias geojsonType\n * @param {GeoJSON} value any GeoJSON object\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction geojsonType(value, type, name) {\n if (!type || !name) throw new Error('type and name required');\n\n if (!value || value.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + value.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link Feature} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @alias featureOf\n * @param {Feature} feature a feature with an expected geometry type\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} error if value is not the expected type.\n */\nfunction featureOf(feature, type, name) {\n if (!feature) throw new Error('No feature passed');\n if (!name) throw new Error('.featureOf() requires a name');\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n}\n\n/**\n * Enforce expectations about types of {@link FeatureCollection} inputs for Turf.\n * Internally this uses {@link geojsonType} to judge geometry types.\n *\n * @alias collectionOf\n * @param {FeatureCollection} featureCollection a FeatureCollection for which features will be judged\n * @param {string} type expected GeoJSON type\n * @param {string} name name of calling function\n * @throws {Error} if value is not the expected type.\n */\nfunction collectionOf(featureCollection, type, name) {\n if (!featureCollection) throw new Error('No featureCollection passed');\n if (!name) throw new Error('.collectionOf() requires a name');\n if (!featureCollection || featureCollection.type !== 'FeatureCollection') {\n throw new Error('Invalid input to ' + name + ', FeatureCollection required');\n }\n for (var i = 0; i < featureCollection.features.length; i++) {\n var feature = featureCollection.features[i];\n if (!feature || feature.type !== 'Feature' || !feature.geometry) {\n throw new Error('Invalid input to ' + name + ', Feature with geometry required');\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error('Invalid input to ' + name + ': must be a ' + type + ', given ' + feature.geometry.type);\n }\n }\n}\n\nmodule.exports.geojsonType = geojsonType;\nmodule.exports.collectionOf = collectionOf;\nmodule.exports.featureOf = featureOf;\nmodule.exports.getCoord = getCoord;\nmodule.exports.getCoords = getCoords;\n","/**\n * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}.\n *\n * @name feature\n * @param {Geometry} geometry input geometry\n * @param {Object} properties properties\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var geometry = {\n * \"type\": \"Point\",\n * \"coordinates\": [\n * 67.5,\n * 32.84267363195431\n * ]\n * }\n *\n * var feature = turf.feature(geometry);\n *\n * //=feature\n */\nfunction feature(geometry, properties) {\n if (!geometry) throw new Error('No geometry passed');\n\n return {\n type: 'Feature',\n properties: properties || {},\n geometry: geometry\n };\n}\nmodule.exports.feature = feature;\n\n/**\n * Takes coordinates and properties (optional) and returns a new {@link Point} feature.\n *\n * @name point\n * @param {Array} coordinates longitude, latitude position (each in decimal degrees)\n * @param {Object=} properties an Object that is used as the {@link Feature}'s\n * properties\n * @returns {Feature} a Point feature\n * @example\n * var pt1 = turf.point([-75.343, 39.984]);\n *\n * //=pt1\n */\nmodule.exports.point = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length === undefined) throw new Error('Coordinates must be an array');\n if (coordinates.length < 2) throw new Error('Coordinates must be at least 2 numbers long');\n if (typeof coordinates[0] !== 'number' || typeof coordinates[1] !== 'number') throw new Error('Coordinates must numbers');\n\n return feature({\n type: 'Point',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Takes an array of LinearRings and optionally an {@link Object} with properties and returns a {@link Polygon} feature.\n *\n * @name polygon\n * @param {Array>>} coordinates an array of LinearRings\n * @param {Object=} properties a properties object\n * @returns {Feature} a Polygon feature\n * @throws {Error} throw an error if a LinearRing of the polygon has too few positions\n * or if a LinearRing of the Polygon does not have matching Positions at the\n * beginning & end.\n * @example\n * var polygon = turf.polygon([[\n * [-2.275543, 53.464547],\n * [-2.275543, 53.489271],\n * [-2.215118, 53.489271],\n * [-2.215118, 53.464547],\n * [-2.275543, 53.464547]\n * ]], { name: 'poly1', population: 400});\n *\n * //=polygon\n */\nmodule.exports.polygon = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n for (var i = 0; i < coordinates.length; i++) {\n var ring = coordinates[i];\n if (ring.length < 4) {\n throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.');\n }\n for (var j = 0; j < ring[ring.length - 1].length; j++) {\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error('First and last Position are not equivalent.');\n }\n }\n }\n\n return feature({\n type: 'Polygon',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link LineString} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name lineString\n * @param {Array>} coordinates an array of Positions\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a LineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var linestring1 = turf.lineString([\n * [-21.964416, 64.148203],\n * [-21.956176, 64.141316],\n * [-21.93901, 64.135924],\n * [-21.927337, 64.136673]\n * ]);\n * var linestring2 = turf.lineString([\n * [-21.929054, 64.127985],\n * [-21.912918, 64.134726],\n * [-21.916007, 64.141016],\n * [-21.930084, 64.14446]\n * ], {name: 'line 1', distance: 145});\n *\n * //=linestring1\n *\n * //=linestring2\n */\nmodule.exports.lineString = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'LineString',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}.\n *\n * @name featureCollection\n * @param {Feature[]} features input features\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var features = [\n * turf.point([-75.343, 39.984], {name: 'Location A'}),\n * turf.point([-75.833, 39.284], {name: 'Location B'}),\n * turf.point([-75.534, 39.123], {name: 'Location C'})\n * ];\n *\n * var fc = turf.featureCollection(features);\n *\n * //=fc\n */\nmodule.exports.featureCollection = function (features) {\n if (!features) throw new Error('No features passed');\n\n return {\n type: 'FeatureCollection',\n features: features\n };\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiLineString\n * @param {Array>>} coordinates an array of LineStrings\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a MultiLineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiLine = turf.multiLineString([[[0,0],[10,10]]]);\n *\n * //=multiLine\n *\n */\nmodule.exports.multiLineString = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiLineString',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPoint\n * @param {Array>} coordinates an array of Positions\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a MultiPoint feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPt = turf.multiPoint([[0,0],[10,10]]);\n *\n * //=multiPt\n *\n */\nmodule.exports.multiPoint = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPoint',\n coordinates: coordinates\n }, properties);\n};\n\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPolygon\n * @param {Array>>>} coordinates an array of Polygons\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a multipolygon feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]);\n *\n * //=multiPoly\n *\n */\nmodule.exports.multiPolygon = function (coordinates, properties) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPolygon',\n coordinates: coordinates\n }, properties);\n};\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name geometryCollection\n * @param {Array<{Geometry}>} geometries an array of GeoJSON Geometries\n * @param {Object=} properties an Object of key-value pairs to add as properties\n * @returns {Feature} a GeoJSON GeometryCollection Feature\n * @example\n * var pt = {\n * \"type\": \"Point\",\n * \"coordinates\": [100, 0]\n * };\n * var line = {\n * \"type\": \"LineString\",\n * \"coordinates\": [ [101, 0], [102, 1] ]\n * };\n * var collection = turf.geometryCollection([pt, line]);\n *\n * //=collection\n */\nmodule.exports.geometryCollection = function (geometries, properties) {\n if (!geometries) throw new Error('No geometries passed');\n\n return feature({\n type: 'GeometryCollection',\n geometries: geometries\n }, properties);\n};\n\nvar factors = {\n miles: 3960,\n nauticalmiles: 3441.145,\n degrees: 57.2957795,\n radians: 1,\n inches: 250905600,\n yards: 6969600,\n meters: 6373000,\n metres: 6373000,\n kilometers: 6373,\n kilometres: 6373,\n feet: 20908792.65\n};\n\n/*\n * Convert a distance measurement from radians to a more friendly unit.\n *\n * @name radiansToDistance\n * @param {number} distance in radians across the sphere\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} distance\n */\nmodule.exports.radiansToDistance = function (radians, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return radians * factor;\n};\n\n/*\n * Convert a distance measurement from a real-world unit into radians\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} radians\n */\nmodule.exports.distanceToRadians = function (distance, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return distance / factor;\n};\n\n/*\n * Convert a distance measurement from a real-world unit into degrees\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} degrees\n */\nmodule.exports.distanceToDegrees = function (distance, units) {\n var factor = factors[units || 'kilometers'];\n if (factor === undefined) throw new Error('Invalid unit');\n\n return (distance / factor) * 57.2958;\n};\n","var invariant = require('@turf/invariant');\nvar getCoords = invariant.getCoords;\n\n/**\n * Takes a ring and return true or false whether or not the ring is clockwise or counter-clockwise.\n *\n * @name booleanClockwise\n * @param {Geometry|Feature|Array>} line to be evaluated\n * @returns {Boolean} true/false\n * @example\n * var clockwiseRing = turf.lineString([[0,0],[1,1],[1,0],[0,0]]);\n * var counterClockwiseRing = turf.lineString([[0,0],[1,0],[1,1],[0,0]]);\n *\n * turf.booleanClockwise(clockwiseRing)\n * //=true\n * turf.booleanClockwise(counterClockwiseRing)\n * //=false\n */\nmodule.exports = function (line) {\n // validation\n if (!line) throw new Error('line is required');\n var type = (line.geometry) ? line.geometry.type : line.type;\n if (!Array.isArray(line) && type !== 'LineString') throw new Error('geometry must be a LineString');\n\n var ring = getCoords(line);\n var sum = 0;\n var i = 1;\n var prev, cur;\n while (i < ring.length) {\n prev = cur || ring[0];\n cur = ring[i];\n sum += ((cur[0] - prev[0]) * (cur[1] + prev[1]));\n i++;\n }\n return sum > 0;\n};\n","'use strict';\n\nvar D2R = Math.PI / 180;\nvar R2D = 180 / Math.PI;\n\nvar Coord = function (lon, lat) {\n this.lon = lon;\n this.lat = lat;\n this.x = D2R * lon;\n this.y = D2R * lat;\n};\n\nCoord.prototype.view = function () {\n return String(this.lon).slice(0, 4) + ',' + String(this.lat).slice(0, 4);\n};\n\nCoord.prototype.antipode = function () {\n var anti_lat = -1 * this.lat;\n var anti_lon = (this.lon < 0) ? 180 + this.lon : (180 - this.lon) * -1;\n return new Coord(anti_lon, anti_lat);\n};\n\nvar LineString = function () {\n this.coords = [];\n this.length = 0;\n};\n\nLineString.prototype.move_to = function (coord) {\n this.length++;\n this.coords.push(coord);\n};\n\nvar Arc = function (properties) {\n this.properties = properties || {};\n this.geometries = [];\n};\n\nArc.prototype.json = function () {\n if (this.geometries.length <= 0) {\n return {'geometry': {'type': 'LineString', 'coordinates': null},\n 'type': 'Feature', 'properties': this.properties\n };\n } else if (this.geometries.length === 1) {\n return {'geometry': {'type': 'LineString', 'coordinates': this.geometries[0].coords},\n 'type': 'Feature', 'properties': this.properties\n };\n } else {\n var multiline = [];\n for (var i = 0; i < this.geometries.length; i++) {\n multiline.push(this.geometries[i].coords);\n }\n return {'geometry': {'type': 'MultiLineString', 'coordinates': multiline},\n 'type': 'Feature', 'properties': this.properties\n };\n }\n};\n\n// TODO - output proper multilinestring\nArc.prototype.wkt = function () {\n var wkt_string = '';\n var wkt = 'LINESTRING(';\n var collect = function (c) { wkt += c[0] + ' ' + c[1] + ','; };\n for (var i = 0; i < this.geometries.length; i++) {\n if (this.geometries[i].coords.length === 0) {\n return 'LINESTRING(empty)';\n } else {\n var coords = this.geometries[i].coords;\n coords.forEach(collect);\n wkt_string += wkt.substring(0, wkt.length - 1) + ')';\n }\n }\n return wkt_string;\n};\n\n/*\n * http://en.wikipedia.org/wiki/Great-circle_distance\n *\n */\nvar GreatCircle = function (start, end, properties) {\n if (!start || start.x === undefined || start.y === undefined) {\n throw new Error('GreatCircle constructor expects two args: start and end objects with x and y properties');\n }\n if (!end || end.x === undefined || end.y === undefined) {\n throw new Error('GreatCircle constructor expects two args: start and end objects with x and y properties');\n }\n this.start = new Coord(start.x, start.y);\n this.end = new Coord(end.x, end.y);\n this.properties = properties || {};\n\n var w = this.start.x - this.end.x;\n var h = this.start.y - this.end.y;\n var z = Math.pow(Math.sin(h / 2.0), 2) +\n Math.cos(this.start.y) *\n Math.cos(this.end.y) *\n Math.pow(Math.sin(w / 2.0), 2);\n this.g = 2.0 * Math.asin(Math.sqrt(z));\n\n if (this.g === Math.PI) {\n throw new Error('it appears ' + start.view() + ' and ' + end.view() + ' are \\'antipodal\\', e.g diametrically opposite, thus there is no single route but rather infinite');\n } else if (isNaN(this.g)) {\n throw new Error('could not calculate great circle between ' + start + ' and ' + end);\n }\n};\n\n/*\n * http://williams.best.vwh.net/avform.htm#Intermediate\n */\nGreatCircle.prototype.interpolate = function (f) {\n var A = Math.sin((1 - f) * this.g) / Math.sin(this.g);\n var B = Math.sin(f * this.g) / Math.sin(this.g);\n var x = A * Math.cos(this.start.y) * Math.cos(this.start.x) + B * Math.cos(this.end.y) * Math.cos(this.end.x);\n var y = A * Math.cos(this.start.y) * Math.sin(this.start.x) + B * Math.cos(this.end.y) * Math.sin(this.end.x);\n var z = A * Math.sin(this.start.y) + B * Math.sin(this.end.y);\n var lat = R2D * Math.atan2(z, Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)));\n var lon = R2D * Math.atan2(y, x);\n return [lon, lat];\n};\n\n\n\n/*\n * Generate points along the great circle\n */\nGreatCircle.prototype.Arc = function (npoints, options) {\n var first_pass = [];\n if (!npoints || npoints <= 2) {\n first_pass.push([this.start.lon, this.start.lat]);\n first_pass.push([this.end.lon, this.end.lat]);\n } else {\n var delta = 1.0 / (npoints - 1);\n for (var i = 0; i < npoints; ++i) {\n var step = delta * i;\n var pair = this.interpolate(step);\n first_pass.push(pair);\n }\n }\n /* partial port of dateline handling from:\n gdal/ogr/ogrgeometryfactory.cpp\n\n TODO - does not handle all wrapping scenarios yet\n */\n var bHasBigDiff = false;\n var dfMaxSmallDiffLong = 0;\n // from http://www.gdal.org/ogr2ogr.html\n // -datelineoffset:\n // (starting with GDAL 1.10) offset from dateline in degrees (default long. = +/- 10deg, geometries within 170deg to -170deg will be splited)\n var dfDateLineOffset = options && options.offset ? options.offset : 10;\n var dfLeftBorderX = 180 - dfDateLineOffset;\n var dfRightBorderX = -180 + dfDateLineOffset;\n var dfDiffSpace = 360 - dfDateLineOffset;\n\n // https://github.com/OSGeo/gdal/blob/7bfb9c452a59aac958bff0c8386b891edf8154ca/gdal/ogr/ogrgeometryfactory.cpp#L2342\n for (var j = 1; j < first_pass.length; ++j) {\n var dfPrevX = first_pass[j - 1][0];\n var dfX = first_pass[j][0];\n var dfDiffLong = Math.abs(dfX - dfPrevX);\n if (dfDiffLong > dfDiffSpace &&\n ((dfX > dfLeftBorderX && dfPrevX < dfRightBorderX) || (dfPrevX > dfLeftBorderX && dfX < dfRightBorderX))) {\n bHasBigDiff = true;\n } else if (dfDiffLong > dfMaxSmallDiffLong) {\n dfMaxSmallDiffLong = dfDiffLong;\n }\n }\n\n var poMulti = [];\n if (bHasBigDiff && dfMaxSmallDiffLong < dfDateLineOffset) {\n var poNewLS = [];\n poMulti.push(poNewLS);\n for (var k = 0; k < first_pass.length; ++k) {\n var dfX0 = parseFloat(first_pass[k][0]);\n if (k > 0 && Math.abs(dfX0 - first_pass[k - 1][0]) > dfDiffSpace) {\n var dfX1 = parseFloat(first_pass[k - 1][0]);\n var dfY1 = parseFloat(first_pass[k - 1][1]);\n var dfX2 = parseFloat(first_pass[k][0]);\n var dfY2 = parseFloat(first_pass[k][1]);\n if (dfX1 > -180 && dfX1 < dfRightBorderX && dfX2 === 180 &&\n k + 1 < first_pass.length &&\n first_pass[k - 1][0] > -180 && first_pass[k - 1][0] < dfRightBorderX) {\n poNewLS.push([-180, first_pass[k][1]]);\n k++;\n poNewLS.push([first_pass[k][0], first_pass[k][1]]);\n continue;\n } else if (dfX1 > dfLeftBorderX && dfX1 < 180 && dfX2 === -180 &&\n k + 1 < first_pass.length &&\n first_pass[k - 1][0] > dfLeftBorderX && first_pass[k - 1][0] < 180) {\n poNewLS.push([180, first_pass[k][1]]);\n k++;\n poNewLS.push([first_pass[k][0], first_pass[k][1]]);\n continue;\n }\n\n if (dfX1 < dfRightBorderX && dfX2 > dfLeftBorderX) {\n // swap dfX1, dfX2\n var tmpX = dfX1;\n dfX1 = dfX2;\n dfX2 = tmpX;\n // swap dfY1, dfY2\n var tmpY = dfY1;\n dfY1 = dfY2;\n dfY2 = tmpY;\n }\n if (dfX1 > dfLeftBorderX && dfX2 < dfRightBorderX) {\n dfX2 += 360;\n }\n if (dfX1 <= 180 && dfX2 >= 180 && dfX1 < dfX2) {\n var dfRatio = (180 - dfX1) / (dfX2 - dfX1);\n var dfY = dfRatio * dfY2 + (1 - dfRatio) * dfY1;\n poNewLS.push([first_pass[k - 1][0] > dfLeftBorderX ? 180 : -180, dfY]);\n poNewLS = [];\n poNewLS.push([first_pass[k - 1][0] > dfLeftBorderX ? -180 : 180, dfY]);\n poMulti.push(poNewLS);\n } else {\n poNewLS = [];\n poMulti.push(poNewLS);\n }\n poNewLS.push([dfX0, first_pass[k][1]]);\n } else {\n poNewLS.push([first_pass[k][0], first_pass[k][1]]);\n }\n }\n } else {\n // add normally\n var poNewLS0 = [];\n poMulti.push(poNewLS0);\n for (var l = 0; l < first_pass.length; ++l) {\n poNewLS0.push([first_pass[l][0], first_pass[l][1]]);\n }\n }\n\n var arc = new Arc(this.properties);\n for (var m = 0; m < poMulti.length; ++m) {\n var line = new LineString();\n arc.geometries.push(line);\n var points = poMulti[m];\n for (var j0 = 0; j0 < points.length; ++j0) {\n line.move_to(points[j0]);\n }\n }\n return arc;\n};\n\nmodule.exports = {\n Coord: Coord,\n Arc: Arc,\n GreatCircle: GreatCircle\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('SimpleTable',{staticClass:\"cultivation-table\",attrs:{\"columns\":_vm.cultivationColumns,\"data\":_vm.cultivations},scopedSlots:_vm._u([{key:\"type\",fn:function(ref){\nvar row = ref.row;\nreturn [_vm._v(\"\\n \"+_vm._s(_vm.cultivationTypeTranslations[row.type])+\"\\n \")]}},{key:\"cropUsageId\",fn:function(ref){\nvar row = ref.row;\nreturn [_c('span',{staticClass:\"cultivation-item\"},[(row.cropUsageId && row.cropUsageId !== '00000000-0000-0000-0000-000000000000')?_c('IxRes',[_vm._v(\"masterData.crops.usage.\"+_vm._s(row.cropUsageId)+\"_name\")]):_vm._e(),(row.underseedMixtureId)?_c('IxRes',{attrs:{\"context\":{mixture: _vm.mixtures[row.underseedMixtureId].name}}},[_vm._v(\"frs.cultivation.underseedMixture\")]):_vm._e()],1)]}},{key:\"dateTimeRange\",fn:function(ref){\nvar ref_value = ref.value;\nvar start = ref_value.start;\nvar end = ref_value.end;\nreturn [_vm._v(\"\\n \"+_vm._s(_vm.$i18n.format(start, 'date'))+\" - \"+_vm._s(_vm.$i18n.format(end, 'date'))+\"\\n \")]}}])})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./FrsCultivationOverviewTable.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!./FrsCultivationOverviewTable.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./FrsCultivationOverviewTable.vue?vue&type=template&id=21f1e008&scoped=true&\"\nimport script from \"./FrsCultivationOverviewTable.vue?vue&type=script&lang=js&\"\nexport * from \"./FrsCultivationOverviewTable.vue?vue&type=script&lang=js&\"\nimport style0 from \"./FrsCultivationOverviewTable.vue?vue&type=style&index=0&id=21f1e008&lang=scss&scoped=true&\"\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 \"21f1e008\",\n null\n \n)\n\nexport default component.exports","/**\n * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}.\n *\n * @name feature\n * @param {Geometry} geometry input geometry\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a GeoJSON Feature\n * @example\n * var geometry = {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 50]\n * };\n *\n * var feature = turf.feature(geometry);\n *\n * //=feature\n */\nfunction feature(geometry, properties, bbox, id) {\n if (geometry === undefined) throw new Error('geometry is required');\n if (properties && properties.constructor !== Object) throw new Error('properties must be an Object');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n if (id && ['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');\n\n var feat = {type: 'Feature'};\n if (id) feat.id = id;\n if (bbox) feat.bbox = bbox;\n feat.properties = properties || {};\n feat.geometry = geometry;\n return feat;\n}\n\n/**\n * Creates a GeoJSON {@link Geometry} from a Geometry string type & coordinates.\n * For GeometryCollection type use `helpers.geometryCollection`\n *\n * @name geometry\n * @param {string} type Geometry Type\n * @param {Array} coordinates Coordinates\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @returns {Geometry} a GeoJSON Geometry\n * @example\n * var type = 'Point';\n * var coordinates = [110, 50];\n *\n * var geometry = turf.geometry(type, coordinates);\n *\n * //=geometry\n */\nfunction geometry(type, coordinates, bbox) {\n // Validation\n if (!type) throw new Error('type is required');\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n\n var geom;\n switch (type) {\n case 'Point': geom = point(coordinates).geometry; break;\n case 'LineString': geom = lineString(coordinates).geometry; break;\n case 'Polygon': geom = polygon(coordinates).geometry; break;\n case 'MultiPoint': geom = multiPoint(coordinates).geometry; break;\n case 'MultiLineString': geom = multiLineString(coordinates).geometry; break;\n case 'MultiPolygon': geom = multiPolygon(coordinates).geometry; break;\n default: throw new Error(type + ' is invalid');\n }\n if (bbox) geom.bbox = bbox;\n return geom;\n}\n\n/**\n * Takes coordinates and properties (optional) and returns a new {@link Point} feature.\n *\n * @name point\n * @param {Array} coordinates longitude, latitude position (each in decimal degrees)\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a Point feature\n * @example\n * var point = turf.point([-75.343, 39.984]);\n *\n * //=point\n */\nfunction point(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length === undefined) throw new Error('Coordinates must be an array');\n if (coordinates.length < 2) throw new Error('Coordinates must be at least 2 numbers long');\n if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) throw new Error('Coordinates must contain numbers');\n\n return feature({\n type: 'Point',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Takes an array of LinearRings and optionally an {@link Object} with properties and returns a {@link Polygon} feature.\n *\n * @name polygon\n * @param {Array>>} coordinates an array of LinearRings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a Polygon feature\n * @throws {Error} throw an error if a LinearRing of the polygon has too few positions\n * or if a LinearRing of the Polygon does not have matching Positions at the beginning & end.\n * @example\n * var polygon = turf.polygon([[\n * [-2.275543, 53.464547],\n * [-2.275543, 53.489271],\n * [-2.215118, 53.489271],\n * [-2.215118, 53.464547],\n * [-2.275543, 53.464547]\n * ]], { name: 'poly1', population: 400});\n *\n * //=polygon\n */\nfunction polygon(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n for (var i = 0; i < coordinates.length; i++) {\n var ring = coordinates[i];\n if (ring.length < 4) {\n throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.');\n }\n for (var j = 0; j < ring[ring.length - 1].length; j++) {\n // Check if first point of Polygon contains two numbers\n if (i === 0 && j === 0 && !isNumber(ring[0][0]) || !isNumber(ring[0][1])) throw new Error('Coordinates must contain numbers');\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error('First and last Position are not equivalent.');\n }\n }\n }\n\n return feature({\n type: 'Polygon',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link LineString} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name lineString\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a LineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var linestring1 = turf.lineString([\n * [-21.964416, 64.148203],\n * [-21.956176, 64.141316],\n * [-21.93901, 64.135924],\n * [-21.927337, 64.136673]\n * ]);\n * var linestring2 = turf.lineString([\n * [-21.929054, 64.127985],\n * [-21.912918, 64.134726],\n * [-21.916007, 64.141016],\n * [-21.930084, 64.14446]\n * ], {name: 'line 1', distance: 145});\n *\n * //=linestring1\n *\n * //=linestring2\n */\nfunction lineString(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length < 2) throw new Error('Coordinates must be an array of two or more positions');\n // Check if first point of LineString contains two numbers\n if (!isNumber(coordinates[0][1]) || !isNumber(coordinates[0][1])) throw new Error('Coordinates must contain numbers');\n\n return feature({\n type: 'LineString',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}.\n *\n * @name featureCollection\n * @param {Feature[]} features input features\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var features = [\n * turf.point([-75.343, 39.984], {name: 'Location A'}),\n * turf.point([-75.833, 39.284], {name: 'Location B'}),\n * turf.point([-75.534, 39.123], {name: 'Location C'})\n * ];\n *\n * var collection = turf.featureCollection(features);\n *\n * //=collection\n */\nfunction featureCollection(features, bbox, id) {\n if (!features) throw new Error('No features passed');\n if (!Array.isArray(features)) throw new Error('features must be an Array');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n if (id && ['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');\n\n var fc = {type: 'FeatureCollection'};\n if (id) fc.id = id;\n if (bbox) fc.bbox = bbox;\n fc.features = features;\n return fc;\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiLineString\n * @param {Array>>} coordinates an array of LineStrings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a MultiLineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiLine = turf.multiLineString([[[0,0],[10,10]]]);\n *\n * //=multiLine\n */\nfunction multiLineString(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiLineString',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPoint\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a MultiPoint feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPt = turf.multiPoint([[0,0],[10,10]]);\n *\n * //=multiPt\n */\nfunction multiPoint(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPoint',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPolygon\n * @param {Array>>>} coordinates an array of Polygons\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a multipolygon feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]);\n *\n * //=multiPoly\n *\n */\nfunction multiPolygon(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPolygon',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name geometryCollection\n * @param {Array} geometries an array of GeoJSON Geometries\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a GeoJSON GeometryCollection Feature\n * @example\n * var pt = {\n * \"type\": \"Point\",\n * \"coordinates\": [100, 0]\n * };\n * var line = {\n * \"type\": \"LineString\",\n * \"coordinates\": [ [101, 0], [102, 1] ]\n * };\n * var collection = turf.geometryCollection([pt, line]);\n *\n * //=collection\n */\nfunction geometryCollection(geometries, properties, bbox, id) {\n if (!geometries) throw new Error('geometries is required');\n if (!Array.isArray(geometries)) throw new Error('geometries must be an Array');\n\n return feature({\n type: 'GeometryCollection',\n geometries: geometries\n }, properties, bbox, id);\n}\n\n// https://en.wikipedia.org/wiki/Great-circle_distance#Radius_for_spherical_Earth\nvar factors = {\n miles: 3960,\n nauticalmiles: 3441.145,\n degrees: 57.2957795,\n radians: 1,\n inches: 250905600,\n yards: 6969600,\n meters: 6373000,\n metres: 6373000,\n centimeters: 6.373e+8,\n centimetres: 6.373e+8,\n kilometers: 6373,\n kilometres: 6373,\n feet: 20908792.65\n};\n\nvar areaFactors = {\n kilometers: 0.000001,\n kilometres: 0.000001,\n meters: 1,\n metres: 1,\n centimetres: 10000,\n millimeter: 1000000,\n acres: 0.000247105,\n miles: 3.86e-7,\n yards: 1.195990046,\n feet: 10.763910417,\n inches: 1550.003100006\n};\n/**\n * Round number to precision\n *\n * @param {number} num Number\n * @param {number} [precision=0] Precision\n * @returns {number} rounded number\n * @example\n * turf.round(120.4321)\n * //=120\n *\n * turf.round(120.4321, 2)\n * //=120.43\n */\nfunction round(num, precision) {\n if (num === undefined || num === null || isNaN(num)) throw new Error('num is required');\n if (precision && !(precision >= 0)) throw new Error('precision must be a positive number');\n var multiplier = Math.pow(10, precision || 0);\n return Math.round(num * multiplier) / multiplier;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from radians to a more friendly unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name radiansToDistance\n * @param {number} radians in radians across the sphere\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} distance\n */\nfunction radiansToDistance(radians, units) {\n if (radians === undefined || radians === null) throw new Error('radians is required');\n\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error('units is invalid');\n return radians * factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into radians\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} radians\n */\nfunction distanceToRadians(distance, units) {\n if (distance === undefined || distance === null) throw new Error('distance is required');\n\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error('units is invalid');\n return distance / factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into degrees\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, centimeters, kilometres, feet\n *\n * @name distanceToDegrees\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} degrees\n */\nfunction distanceToDegrees(distance, units) {\n return radians2degrees(distanceToRadians(distance, units));\n}\n\n/**\n * Converts any bearing angle from the north line direction (positive clockwise)\n * and returns an angle between 0-360 degrees (positive clockwise), 0 being the north line\n *\n * @name bearingToAngle\n * @param {number} bearing angle, between -180 and +180 degrees\n * @returns {number} angle between 0 and 360 degrees\n */\nfunction bearingToAngle(bearing) {\n if (bearing === null || bearing === undefined) throw new Error('bearing is required');\n\n var angle = bearing % 360;\n if (angle < 0) angle += 360;\n return angle;\n}\n\n/**\n * Converts an angle in radians to degrees\n *\n * @name radians2degrees\n * @param {number} radians angle in radians\n * @returns {number} degrees between 0 and 360 degrees\n */\nfunction radians2degrees(radians) {\n if (radians === null || radians === undefined) throw new Error('radians is required');\n\n var degrees = radians % (2 * Math.PI);\n return degrees * 180 / Math.PI;\n}\n\n/**\n * Converts an angle in degrees to radians\n *\n * @name degrees2radians\n * @param {number} degrees angle between 0 and 360 degrees\n * @returns {number} angle in radians\n */\nfunction degrees2radians(degrees) {\n if (degrees === null || degrees === undefined) throw new Error('degrees is required');\n\n var radians = degrees % 360;\n return radians * Math.PI / 180;\n}\n\n\n/**\n * Converts a distance to the requested unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @param {number} distance to be converted\n * @param {string} originalUnit of the distance\n * @param {string} [finalUnit=kilometers] returned unit\n * @returns {number} the converted distance\n */\nfunction convertDistance(distance, originalUnit, finalUnit) {\n if (distance === null || distance === undefined) throw new Error('distance is required');\n if (!(distance >= 0)) throw new Error('distance must be a positive number');\n\n var convertedDistance = radiansToDistance(distanceToRadians(distance, originalUnit), finalUnit || 'kilometers');\n return convertedDistance;\n}\n\n/**\n * Converts a area to the requested unit.\n * Valid units: kilometers, kilometres, meters, metres, centimetres, millimeter, acre, mile, yard, foot, inch\n * @param {number} area to be converted\n * @param {string} [originalUnit=meters] of the distance\n * @param {string} [finalUnit=kilometers] returned unit\n * @returns {number} the converted distance\n */\nfunction convertArea(area, originalUnit, finalUnit) {\n if (area === null || area === undefined) throw new Error('area is required');\n if (!(area >= 0)) throw new Error('area must be a positive number');\n\n var startFactor = areaFactors[originalUnit || 'meters'];\n if (!startFactor) throw new Error('invalid original units');\n\n var finalFactor = areaFactors[finalUnit || 'kilometers'];\n if (!finalFactor) throw new Error('invalid final units');\n\n return (area / startFactor) * finalFactor;\n}\n\n/**\n * isNumber\n *\n * @param {*} num Number to validate\n * @returns {boolean} true/false\n * @example\n * turf.isNumber(123)\n * //=true\n * turf.isNumber('foo')\n * //=false\n */\nfunction isNumber(num) {\n return !isNaN(num) && num !== null && !Array.isArray(num);\n}\n\nmodule.exports = {\n feature: feature,\n geometry: geometry,\n featureCollection: featureCollection,\n geometryCollection: geometryCollection,\n point: point,\n multiPoint: multiPoint,\n lineString: lineString,\n multiLineString: multiLineString,\n polygon: polygon,\n multiPolygon: multiPolygon,\n radiansToDistance: radiansToDistance,\n distanceToRadians: distanceToRadians,\n distanceToDegrees: distanceToDegrees,\n radians2degrees: radians2degrees,\n degrees2radians: degrees2radians,\n bearingToAngle: bearingToAngle,\n convertDistance: convertDistance,\n convertArea: convertArea,\n round: round,\n isNumber: isNumber\n};\n","var destination = require('@turf/destination');\nvar circle = require('@turf/circle');\nvar lineString = require('@turf/helpers').lineString;\n\n/**\n * Creates a circular arc, of a circle of the given radius and center point, between bearing1 and bearing2;\n * 0 bearing is North of center point, positive clockwise.\n *\n * @name lineArc\n * @param {Feature} center center point\n * @param {number} radius radius of the circle\n * @param {number} bearing1 angle, in decimal degrees, of the first radius of the arc\n * @param {number} bearing2 angle, in decimal degrees, of the second radius of the arc\n * @param {number} [steps=64] number of steps\n * @param {string} [units=kilometers] miles, kilometers, degrees, or radians\n * @returns {Feature} line arc\n * @example\n * var center = turf.point([-75, 40]);\n * var radius = 5;\n * var bearing1 = 25;\n * var bearing2 = 47;\n *\n * var arc = turf.lineArc(center, radius, bearing1, bearing2);\n *\n * //addToMap\n * var addToMap = [center, arc]\n */\nmodule.exports = function (center, radius, bearing1, bearing2, steps, units) {\n // validation\n if (!center) throw new Error('center is required');\n if (bearing1 === undefined || bearing1 === null) throw new Error('bearing1 is required');\n if (bearing2 === undefined || bearing2 === null) throw new Error('bearing2 is required');\n if (!radius) throw new Error('radius is required');\n\n // default params\n steps = steps || 64;\n\n var angle1 = convertAngleTo360(bearing1);\n var angle2 = convertAngleTo360(bearing2);\n var properties = center.properties;\n\n // handle angle parameters\n if (angle1 === angle2) {\n return lineString(circle(center, radius, steps, units).geometry.coordinates[0], properties);\n }\n var arcStartDegree = angle1;\n var arcEndDegree = (angle1 < angle2) ? angle2 : angle2 + 360;\n\n var alfa = arcStartDegree;\n var coordinates = [];\n var i = 0;\n\n while (alfa < arcEndDegree) {\n coordinates.push(destination(center, radius, alfa, units).geometry.coordinates);\n i++;\n alfa = arcStartDegree + i * 360 / steps;\n }\n if (alfa > arcEndDegree) {\n coordinates.push(destination(center, radius, arcEndDegree, units).geometry.coordinates);\n }\n return lineString(coordinates, properties);\n};\n\n\n/**\n * Takes any angle in degrees\n * and returns a valid angle between 0-360 degrees\n *\n * @private\n * @param {number} alfa angle between -180-180 degrees\n * @returns {number} angle between 0-360 degrees\n */\nfunction convertAngleTo360(alfa) {\n var beta = alfa % 360;\n if (beta < 0) {\n beta += 360;\n }\n return beta;\n}\n","var inside = require('@turf/inside');\n\n/**\n * Takes a set of {@link Point|points} and a set of {@link Polygon|polygons} and performs a spatial join.\n *\n * @name tag\n * @param {FeatureCollection} points input points\n * @param {FeatureCollection} polygons input polygons\n * @param {string} field property in `polygons` to add to joined {} features\n * @param {string} outField property in `points` in which to store joined property from `polygons`\n * @returns {FeatureCollection} points with `containingPolyId` property containing values from `polyId`\n * @example\n * var pt1 = turf.point([-77, 44]);\n * var pt2 = turf.point([-77, 38]);\n * var poly1 = turf.polygon([[\n * [-81, 41],\n * [-81, 47],\n * [-72, 47],\n * [-72, 41],\n * [-81, 41]\n * ]], {pop: 3000});\n * var poly2 = turf.polygon([[\n * [-81, 35],\n * [-81, 41],\n * [-72, 41],\n * [-72, 35],\n * [-81, 35]\n * ]], {pop: 1000});\n *\n * var points = turf.featureCollection([pt1, pt2]);\n * var polygons = turf.featureCollection([poly1, poly2]);\n *\n * var tagged = turf.tag(points, polygons, 'pop', 'population');\n *\n * //addToMap\n * var addToMap = [tagged, polygons]\n */\nmodule.exports = function (points, polygons, field, outField) {\n // prevent mutations\n points = JSON.parse(JSON.stringify(points));\n polygons = JSON.parse(JSON.stringify(polygons));\n points.features.forEach(function (pt) {\n if (!pt.properties) {\n pt.properties = {};\n }\n polygons.features.forEach(function (poly) {\n if (pt.properties[outField] === undefined) {\n var isInside = inside(pt, poly);\n if (isInside) {\n pt.properties[outField] = poly.properties[field];\n }\n }\n });\n });\n return points;\n};\n","\"use strict\"\n\nmodule.exports = twoProduct\n\nvar SPLITTER = +(Math.pow(2, 27) + 1.0)\n\nfunction twoProduct(a, b, result) {\n var x = a * b\n\n var c = SPLITTER * a\n var abig = c - a\n var ahi = c - abig\n var alo = a - ahi\n\n var d = SPLITTER * b\n var bbig = d - b\n var bhi = d - bbig\n var blo = b - bhi\n\n var err1 = x - (ahi * bhi)\n var err2 = err1 - (alo * bhi)\n var err3 = err2 - (ahi * blo)\n\n var y = alo * blo - err3\n\n if(result) {\n result[0] = y\n result[1] = x\n return result\n }\n\n return [ y, x ]\n}","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FrsCultivationOverviewTable.vue?vue&type=style&index=0&id=21f1e008&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./FrsCultivationOverviewTable.vue?vue&type=style&index=0&id=21f1e008&lang=scss&scoped=true&\"","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Geodesy representation conversion functions (c) Chris Veness 2002-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-dms.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\n/* eslint no-irregular-whitespace: [2, { skipComments: true }] */\n\n\n/**\n * Latitude/longitude points may be represented as decimal degrees, or subdivided into sexagesimal\n * minutes and seconds.\n *\n * @module dms\n */\n\n\n/**\n * Functions for parsing and representing degrees / minutes / seconds.\n * @class Dms\n */\nvar Dms = {};\n\n// note Unicode Degree = U+00B0. Prime = U+2032, Double prime = U+2033\n\n\n/**\n * Parses string representing degrees/minutes/seconds into numeric degrees.\n *\n * This is very flexible on formats, allowing signed decimal degrees, or deg-min-sec optionally\n * suffixed by compass direction (NSEW). A variety of separators are accepted (eg 3° 37′ 09″W).\n * Seconds and minutes may be omitted.\n *\n * @param {string|number} dmsStr - Degrees or deg/min/sec in variety of formats.\n * @returns {number} Degrees as decimal number.\n *\n * @example\n * var lat = Dms.parseDMS('51° 28′ 40.12″ N');\n * var lon = Dms.parseDMS('000° 00′ 05.31″ W');\n * var p1 = new LatLon(lat, lon); // 51.4778°N, 000.0015°W\n */\nDms.parseDMS = function(dmsStr) {\n // check for signed decimal degrees without NSEW, if so return it directly\n if (typeof dmsStr == 'number' && isFinite(dmsStr)) return Number(dmsStr);\n\n // strip off any sign or compass dir'n & split out separate d/m/s\n var dms = String(dmsStr).trim().replace(/^-/, '').replace(/[NSEW]$/i, '').split(/[^0-9.,]+/);\n if (dms[dms.length-1]=='') dms.splice(dms.length-1); // from trailing symbol\n\n if (dms == '') return NaN;\n\n // and convert to decimal degrees...\n var deg;\n switch (dms.length) {\n case 3: // interpret 3-part result as d/m/s\n deg = dms[0]/1 + dms[1]/60 + dms[2]/3600;\n break;\n case 2: // interpret 2-part result as d/m\n deg = dms[0]/1 + dms[1]/60;\n break;\n case 1: // just d (possibly decimal) or non-separated dddmmss\n deg = dms[0];\n // check for fixed-width unseparated format eg 0033709W\n //if (/[NS]/i.test(dmsStr)) deg = '0' + deg; // - normalise N/S to 3-digit degrees\n //if (/[0-9]{7}/.test(deg)) deg = deg.slice(0,3)/1 + deg.slice(3,5)/60 + deg.slice(5)/3600;\n break;\n default:\n return NaN;\n }\n if (/^-|[WS]$/i.test(dmsStr.trim())) deg = -deg; // take '-', west and south as -ve\n\n return Number(deg);\n};\n\n\n/**\n * Separator character to be used to separate degrees, minutes, seconds, and cardinal directions.\n *\n * Set to '\\u202f' (narrow no-break space) for improved formatting.\n *\n * @example\n * var p = new LatLon(51.2, 0.33); // 51°12′00.0″N, 000°19′48.0″E\n * Dms.separator = '\\u202f'; // narrow no-break space\n * var pʹ = new LatLon(51.2, 0.33); // 51° 12′ 00.0″ N, 000° 19′ 48.0″ E\n */\nDms.separator = '';\n\n\n/**\n * Converts decimal degrees to deg/min/sec format\n * - degree, prime, double-prime symbols are added, but sign is discarded, though no compass\n * direction is added.\n *\n * @private\n * @param {number} deg - Degrees to be formatted as specified.\n * @param {string} [format=dms] - Return value as 'd', 'dm', 'dms' for deg, deg+min, deg+min+sec.\n * @param {number} [dp=0|2|4] - Number of decimal places to use – default 0 for dms, 2 for dm, 4 for d.\n * @returns {string} Degrees formatted as deg/min/secs according to specified format.\n */\nDms.toDMS = function(deg, format, dp) {\n if (isNaN(deg)) return null; // give up here if we can't make a number from deg\n\n // default values\n if (format === undefined) format = 'dms';\n if (dp === undefined) {\n switch (format) {\n case 'd': case 'deg': dp = 4; break;\n case 'dm': case 'deg+min': dp = 2; break;\n case 'dms': case 'deg+min+sec': dp = 0; break;\n default: format = 'dms'; dp = 0; // be forgiving on invalid format\n }\n }\n\n deg = Math.abs(deg); // (unsigned result ready for appending compass dir'n)\n\n var dms, d, m, s;\n switch (format) {\n default: // invalid format spec!\n case 'd': case 'deg':\n d = deg.toFixed(dp); // round/right-pad degrees\n if (d<100) d = '0' + d; // left-pad with leading zeros (note may include decimals)\n if (d<10) d = '0' + d;\n dms = d + '°';\n break;\n case 'dm': case 'deg+min':\n d = Math.floor(deg); // get component deg\n m = ((deg*60) % 60).toFixed(dp); // get component min & round/right-pad\n if (m == 60) { m = 0; d++; } // check for rounding up\n d = ('000'+d).slice(-3); // left-pad with leading zeros\n if (m<10) m = '0' + m; // left-pad with leading zeros (note may include decimals)\n dms = d + '°'+Dms.separator + m + '′';\n break;\n case 'dms': case 'deg+min+sec':\n d = Math.floor(deg); // get component deg\n m = Math.floor((deg*3600)/60) % 60; // get component min\n s = (deg*3600 % 60).toFixed(dp); // get component sec & round/right-pad\n if (s == 60) { s = (0).toFixed(dp); m++; } // check for rounding up\n if (m == 60) { m = 0; d++; } // check for rounding up\n d = ('000'+d).slice(-3); // left-pad with leading zeros\n m = ('00'+m).slice(-2); // left-pad with leading zeros\n if (s<10) s = '0' + s; // left-pad with leading zeros (note may include decimals)\n dms = d + '°'+Dms.separator + m + '′'+Dms.separator + s + '″';\n break;\n }\n\n return dms;\n};\n\n\n/**\n * Converts numeric degrees to deg/min/sec latitude (2-digit degrees, suffixed with N/S).\n *\n * @param {number} deg - Degrees to be formatted as specified.\n * @param {string} [format=dms] - Return value as 'd', 'dm', 'dms' for deg, deg+min, deg+min+sec.\n * @param {number} [dp=0|2|4] - Number of decimal places to use – default 0 for dms, 2 for dm, 4 for d.\n * @returns {string} Degrees formatted as deg/min/secs according to specified format.\n */\nDms.toLat = function(deg, format, dp) {\n var lat = Dms.toDMS(deg, format, dp);\n return lat===null ? '–' : lat.slice(1)+Dms.separator + (deg<0 ? 'S' : 'N'); // knock off initial '0' for lat!\n};\n\n\n/**\n * Convert numeric degrees to deg/min/sec longitude (3-digit degrees, suffixed with E/W)\n *\n * @param {number} deg - Degrees to be formatted as specified.\n * @param {string} [format=dms] - Return value as 'd', 'dm', 'dms' for deg, deg+min, deg+min+sec.\n * @param {number} [dp=0|2|4] - Number of decimal places to use – default 0 for dms, 2 for dm, 4 for d.\n * @returns {string} Degrees formatted as deg/min/secs according to specified format.\n */\nDms.toLon = function(deg, format, dp) {\n var lon = Dms.toDMS(deg, format, dp);\n return lon===null ? '–' : lon+Dms.separator + (deg<0 ? 'W' : 'E');\n};\n\n\n/**\n * Converts numeric degrees to deg/min/sec as a bearing (0°..360°)\n *\n * @param {number} deg - Degrees to be formatted as specified.\n * @param {string} [format=dms] - Return value as 'd', 'dm', 'dms' for deg, deg+min, deg+min+sec.\n * @param {number} [dp=0|2|4] - Number of decimal places to use – default 0 for dms, 2 for dm, 4 for d.\n * @returns {string} Degrees formatted as deg/min/secs according to specified format.\n */\nDms.toBrng = function(deg, format, dp) {\n deg = (Number(deg)+360) % 360; // normalise -ve values to 180°..360°\n var brng = Dms.toDMS(deg, format, dp);\n return brng===null ? '–' : brng.replace('360', '0'); // just in case rounding took us up to 360°!\n};\n\n\n/**\n * Returns compass point (to given precision) for supplied bearing.\n *\n * @param {number} bearing - Bearing in degrees from north.\n * @param {number} [precision=3] - Precision (1:cardinal / 2:intercardinal / 3:secondary-intercardinal).\n * @returns {string} Compass point for supplied bearing.\n *\n * @example\n * var point = Dms.compassPoint(24); // point = 'NNE'\n * var point = Dms.compassPoint(24, 1); // point = 'N'\n */\nDms.compassPoint = function(bearing, precision) {\n if (precision === undefined) precision = 3;\n // note precision could be extended to 4 for quarter-winds (eg NbNW), but I think they are little used\n\n bearing = ((bearing%360)+360)%360; // normalise to range 0..360°\n\n var cardinals = [\n 'N', 'NNE', 'NE', 'ENE',\n 'E', 'ESE', 'SE', 'SSE',\n 'S', 'SSW', 'SW', 'WSW',\n 'W', 'WNW', 'NW', 'NNW' ];\n var n = 4 * Math.pow(2, precision-1); // no of compass points at req’d precision (1=>4, 2=>8, 3=>16)\n var cardinal = cardinals[Math.round(bearing*n/360)%n * 16/n];\n\n return cardinal;\n};\n\n\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\nif (typeof module != 'undefined' && module.exports) module.exports = Dms; // ≡ export default Dms\n","module.exports = mergeViableLineStrings\n\n// [Number, Number] -> String\nfunction coordId (coord) {\n return coord[0].toString() + ',' + coord[1].toString()\n}\n\n// LineString, LineString -> LineString\nfunction mergeLineStrings (a, b) {\n var s1 = coordId(a.coordinates[0])\n var e1 = coordId(a.coordinates[a.coordinates.length - 1])\n var s2 = coordId(b.coordinates[0])\n var e2 = coordId(b.coordinates[b.coordinates.length - 1])\n\n // TODO: handle case where more than one of these is true!\n\n var coords\n if (s1 === e2) {\n coords = b.coordinates.concat(a.coordinates.slice(1))\n } else if (s2 === e1) {\n coords = a.coordinates.concat(b.coordinates.slice(1))\n } else if (s1 === s2) {\n coords = a.coordinates.slice(1).reverse().concat(b.coordinates)\n } else if (e1 === e2) {\n coords = a.coordinates.concat(b.coordinates.reverse().slice(1))\n } else {\n return null\n }\n\n return {\n type: 'LineString',\n coordinates: coords\n }\n}\n\n// Merges all connected (non-forking, non-junctioning) line strings into single\n// line strings.\n// [LineString] -> LineString|MultiLineString\nfunction mergeViableLineStrings (geoms) {\n // TODO: assert all are linestrings\n\n var lineStrings = geoms.slice()\n var result = []\n while (lineStrings.length > 0) {\n var ls = lineStrings.shift()\n\n // Attempt to merge this LineString with the other LineStrings, updating\n // the reference as it is merged with others and grows.\n lineStrings = lineStrings.reduce(function (accum, cur) {\n var merged = mergeLineStrings(ls, cur)\n if (merged) {\n // Accumulate the merged LineString\n ls = merged\n } else {\n // Put the unmerged LineString back into the list\n accum.push(cur)\n }\n return accum\n }, [])\n\n result.push(ls)\n }\n\n if (result.length === 1) {\n result = result[0]\n } else {\n result = {\n type: 'MultiLineString',\n coordinates: result.map(function (ls) { return ls.coordinates })\n }\n }\n return result\n}\n\n","var area = require('@mapbox/geojson-area').geometry;\nvar geomReduce = require('@turf/meta').geomReduce;\n\n/**\n * Takes one or more features and returns their area in square meters.\n *\n * @name area\n * @param {FeatureCollection|Feature} geojson input GeoJSON feature(s)\n * @returns {number} area in square meters\n * @addToMap polygon\n * @example\n * var polygon = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [\n * [\n * [125, -15],\n * [113, -22],\n * [117, -37],\n * [130, -33],\n * [148, -39],\n * [154, -27],\n * [144, -15],\n * [125, -15]\n * ]\n * ]\n * }\n * }\n * var area = turf.area(polygon);\n * //=area => square meters\n * //=polygon\n */\nmodule.exports = function (geojson) {\n return geomReduce(geojson, function (value, geometry) {\n return value + area(geometry);\n }, 0);\n};\n","var bbox = require('@turf/bbox');\nvar getCoords = require('@turf/invariant').getCoords;\nvar helpers = require('@turf/helpers');\nvar polygon = helpers.polygon;\nvar multiPolygon = helpers.multiPolygon;\nvar lineString = helpers.lineString;\n\n/**\n * Converts (Multi)LineString(s) to Polygon(s).\n *\n * @name lineStringToPolygon\n * @param {FeatureCollection|Feature} lines Features to convert\n * @param {Object} [properties] translates GeoJSON properties to Feature\n * @param {boolean} [autoComplete=true] auto complete linestrings (matches first & last coordinates)\n * @param {boolean} [orderCoords=true] sorts linestrings to place outer ring at the first position of the coordinates\n * @returns {Feature} converted to Polygons\n * @example\n * var line = turf.lineString([[125, -30], [145, -30], [145, -20], [125, -20], [125, -30]]);\n *\n * var polygon = turf.lineStringToPolygon(line);\n *\n * //addToMap\n * var addToMap = [polygon];\n */\nmodule.exports = function (lines, properties, autoComplete, orderCoords) {\n // validation\n if (!lines) throw new Error('lines is required');\n\n // default params\n autoComplete = (autoComplete !== undefined) ? autoComplete : true;\n orderCoords = (orderCoords !== undefined) ? orderCoords : true;\n var type = geomType(lines);\n\n switch (type) {\n case 'FeatureCollection':\n case 'GeometryCollection':\n var coords = [];\n var features = (lines.features) ? lines.features : lines.geometries;\n features.forEach(function (line) {\n coords.push(getCoords(lineStringToPolygon(line, {}, autoComplete, orderCoords)));\n });\n return multiPolygon(coords, properties);\n }\n return lineStringToPolygon(lines, properties, autoComplete, orderCoords);\n};\n\n/**\n * LineString to Polygon\n *\n * @private\n * @param {Feature} line line\n * @param {Object} [properties] translates GeoJSON properties to Feature\n * @param {boolean} [autoComplete=true] auto complete linestrings\n * @param {boolean} [orderCoords=true] sorts linestrings to place outer ring at the first position of the coordinates\n * @returns {Feature} line converted to Polygon\n */\nfunction lineStringToPolygon(line, properties, autoComplete, orderCoords) {\n properties = properties || line.properties || {};\n var coords = getCoords(line);\n var type = geomType(line);\n\n if (!coords.length) throw new Error('line must contain coordinates');\n\n switch (type) {\n case 'LineString':\n if (autoComplete) coords = autoCompleteCoords(coords);\n return polygon([coords], properties);\n case 'MultiLineString':\n var multiCoords = [];\n var largestArea = 0;\n\n coords.forEach(function (coord) {\n if (autoComplete) coord = autoCompleteCoords(coord);\n\n // Largest LineString to be placed in the first position of the coordinates array\n if (orderCoords) {\n var area = calculateArea(bbox(lineString(coord)));\n if (area > largestArea) {\n multiCoords.unshift(coord);\n largestArea = area;\n } else multiCoords.push(coord);\n } else {\n multiCoords.push(coord);\n }\n });\n return polygon(multiCoords, properties);\n default:\n throw new Error('geometry type ' + type + ' is not supported');\n }\n}\n\nfunction geomType(feature) {\n return (feature.geometry) ? feature.geometry.type : feature.type;\n}\n\n/**\n * Auto Complete Coords - matches first & last coordinates\n *\n * @private\n * @param {Array>} coords Coordinates\n * @returns {Array>} auto completed coordinates\n */\nfunction autoCompleteCoords(coords) {\n var first = coords[0];\n var x1 = first[0];\n var y1 = first[1];\n var last = coords[coords.length - 1];\n var x2 = last[0];\n var y2 = last[1];\n if (x1 !== x2 || y1 !== y2) {\n coords.push(first);\n }\n return coords;\n}\n\n/**\n * area - quick approximate area calculation (used to sort)\n *\n * @private\n * @param {[number, number, number, number]} bbox BBox [west, south, east, north]\n * @returns {number} very quick area calculation\n */\nfunction calculateArea(bbox) {\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n return Math.abs(west - east) * Math.abs(south - north);\n}\n","'use strict';\n\nvar Graph = require('./Graph'),\n EdgeRing = require('./EdgeRing'),\n _require = require('@turf/helpers'),\n featureCollection = _require.featureCollection;\n\n/**\n * Polygonizes {@link LineString|(Multi)LineString(s)} into {@link Polygons}.\n *\n * Implementation of GEOSPolygonize function (`geos::operation::polygonize::Polygonizer`).\n *\n * Polygonizes a set of lines that represents edges in a planar graph. Edges must be correctly\n * noded, i.e., they must only meet at their endpoints.\n *\n * The implementation correctly handles:\n *\n * - Dangles: edges which have one or both ends which are not incident on another edge endpoint.\n * - Cut Edges (bridges): edges that are connected at both ends but which do not form part of a polygon.\n *\n * @name polygonize\n * @param {FeatureCollection|Geometry|Feature} geoJson Lines in order to polygonize\n * @returns {FeatureCollection} Polygons created\n * @throws {Error} if geoJson is invalid.\n */\nmodule.exports = function polygonize(geoJson) {\n var graph = Graph.fromGeoJson(geoJson);\n\n // 1. Remove dangle node\n graph.deleteDangles();\n\n // 2. Remove cut-edges (bridge edges)\n graph.deleteCutEdges();\n\n // 3. Get all holes and shells\n var holes = [],\n shells = [];\n\n graph.getEdgeRings().filter(function (edgeRing) {\n return edgeRing.isValid();\n }).forEach(function (edgeRing) {\n if (edgeRing.isHole()) holes.push(edgeRing);else shells.push(edgeRing);\n });\n\n // 4. Assign Holes to Shells\n holes.forEach(function (hole) {\n if (EdgeRing.findEdgeRingContaining(hole, shells)) shells.push(hole);\n });\n\n // 5. EdgeRings to Polygons\n return featureCollection(shells.map(function (shell) {\n return shell.toPolygon();\n }));\n};","import * as helpers from '@turf/helpers';\nimport {\n point,\n polygon,\n lineString,\n multiPoint,\n multiPolygon,\n multiLineString,\n feature,\n geometry,\n featureCollection,\n geometryCollection,\n radiansToDistance,\n distanceToRadians,\n distanceToDegrees,\n bearingToAngle,\n radians2degrees,\n degrees2radians,\n round,\n convertDistance,\n convertArea,\n isNumber} from '@turf/helpers';\nimport * as invariant from '@turf/invariant';\nimport {\n getGeom,\n getGeomType,\n getCoord,\n getCoords,\n geojsonType,\n featureOf,\n collectionOf,\n containsNumber} from '@turf/invariant';\nimport * as meta from '@turf/meta';\nimport {\n coordEach,\n coordReduce,\n propEach,\n propReduce,\n featureEach,\n featureReduce,\n coordAll,\n geomEach,\n geomReduce,\n flattenEach,\n flattenReduce,\n segmentEach,\n segmentReduce,\n lineEach, // v4.7.0\n lineReduce // v4.7.0\n} from '@turf/meta';\nimport * as isolines from '@turf/isolines';\nimport * as convex from '@turf/convex';\nimport * as within from '@turf/within';\nimport * as concave from '@turf/concave';\nimport * as difference from '@turf/difference';\nimport * as dissolve from '@turf/dissolve';\nimport * as collect from '@turf/collect';\nimport * as flip from '@turf/flip';\nimport * as simplify from '@turf/simplify';\nimport * as bezier from '@turf/bezier';\nimport * as tag from '@turf/tag';\nimport * as sample from '@turf/sample';\nimport * as envelope from '@turf/envelope';\nimport * as square from '@turf/square';\nimport * as circle from '@turf/circle';\nimport * as midpoint from '@turf/midpoint';\nimport * as buffer from '@turf/buffer';\nimport * as center from '@turf/center';\nimport * as centerOfMass from '@turf/center-of-mass';\nimport * as centroid from '@turf/centroid';\nimport * as combine from '@turf/combine';\nimport * as distance from '@turf/distance';\nimport * as explode from '@turf/explode';\nimport * as bbox from '@turf/bbox';\nimport * as tesselate from '@turf/tesselate';\nimport * as bboxPolygon from '@turf/bbox-polygon';\nimport * as inside from '@turf/inside';\nimport * as intersect from '@turf/intersect';\nimport * as nearest from '@turf/nearest';\nimport * as planepoint from '@turf/planepoint';\nimport * as random from '@turf/random';\nimport * as tin from '@turf/tin';\nimport * as union from '@turf/union';\nimport * as bearing from '@turf/bearing';\nimport * as destination from '@turf/destination';\nimport * as kinks from '@turf/kinks';\nimport * as pointOnSurface from '@turf/point-on-surface';\nimport * as area from '@turf/area';\nimport * as along from '@turf/along';\nimport * as lineDistance from '@turf/line-distance';\nimport * as lineSlice from '@turf/line-slice';\nimport * as lineSliceAlong from '@turf/line-slice-along';\nimport * as pointOnLine from '@turf/point-on-line';\nimport * as pointGrid from '@turf/point-grid';\nimport * as squareGrid from '@turf/square-grid';\nimport * as triangleGrid from '@turf/triangle-grid';\nimport * as hexGrid from '@turf/hex-grid';\nimport * as idw from '@turf/idw';\nimport * as truncate from '@turf/truncate';\nimport * as flatten from '@turf/flatten';\nimport * as lineIntersect from '@turf/line-intersect';\nimport * as mask from '@turf/mask';\nimport * as lineChunk from '@turf/line-chunk';\nimport * as unkinkPolygon from '@turf/unkink-polygon';\nimport * as greatCircle from '@turf/great-circle';\nimport * as lineSegment from '@turf/line-segment';\nimport * as lineSplit from '@turf/line-split';\nimport * as lineArc from '@turf/line-arc';\nimport * as polygonToLineString from '@turf/polygon-to-linestring';\nimport * as lineStringToPolygon from '@turf/linestring-to-polygon';\nimport * as bboxClip from '@turf/bbox-clip';\nimport * as lineOverlap from '@turf/line-overlap';\nimport * as sector from '@turf/sector';\nimport * as rhumbBearing from '@turf/rhumb-bearing';\nimport * as rhumbDistance from '@turf/rhumb-distance';\nimport * as rhumbDestination from '@turf/rhumb-destination';\nimport * as polygonTangents from '@turf/polygon-tangents';\nimport * as rewind from '@turf/rewind';\nimport * as isobands from '@turf/isobands';\nimport * as transformRotate from '@turf/transform-rotate';\nimport * as transformScale from '@turf/transform-scale';\nimport * as transformTranslate from '@turf/transform-translate';\nimport * as lineOffset from '@turf/line-offset';\nimport * as polygonize from '@turf/polygonize';\nimport * as booleanDisjoint from '@turf/boolean-disjoint';\nimport * as booleanContains from '@turf/boolean-contains';\nimport * as booleanCrosses from '@turf/boolean-crosses';\nimport * as booleanClockwise from '@turf/boolean-clockwise';\nimport * as booleanEqual from '@turf/boolean-equal';\nimport * as booleanWithin from '@turf/boolean-within'; // 4.7.0\nimport * as clone from '@turf/clone';\nimport * as cleanCoords from '@turf/clean-coords';\nimport * as pointToLineDistance from '@turf/point-to-line-distance'; // v4.7.0\nexport {\n isolines,\n convex,\n within,\n concave,\n difference,\n dissolve,\n collect,\n flip,\n simplify,\n bezier,\n tag,\n sample,\n envelope,\n square,\n circle,\n midpoint,\n buffer,\n center,\n centerOfMass,\n centroid,\n combine,\n distance,\n explode,\n bbox,\n tesselate,\n bboxPolygon,\n inside,\n intersect,\n nearest,\n planepoint,\n random,\n tin,\n union,\n bearing,\n destination,\n kinks,\n pointOnSurface,\n area,\n along,\n lineDistance,\n lineSlice,\n lineSliceAlong,\n pointOnLine,\n pointGrid,\n squareGrid,\n triangleGrid,\n hexGrid,\n idw,\n point,\n polygon,\n lineString,\n multiPoint,\n multiPolygon,\n multiLineString,\n feature,\n geometry,\n featureCollection,\n geometryCollection,\n radiansToDistance,\n distanceToRadians,\n distanceToDegrees,\n getCoord,\n getCoords,\n getGeom,\n getGeomType,\n geojsonType,\n featureOf,\n collectionOf,\n containsNumber,\n truncate,\n flatten,\n coordEach,\n coordReduce,\n propEach,\n propReduce,\n featureEach,\n coordAll,\n geomEach,\n lineIntersect,\n mask,\n lineChunk,\n unkinkPolygon,\n greatCircle,\n lineSegment,\n lineSplit,\n lineArc,\n polygonToLineString,\n lineStringToPolygon,\n bboxClip,\n lineOverlap,\n sector,\n rhumbBearing,\n rhumbDistance,\n rhumbDestination,\n polygonTangents,\n rewind,\n isobands,\n radians2degrees,\n degrees2radians,\n round,\n flattenEach,\n flattenReduce,\n convertDistance,\n convertArea,\n transformRotate,\n transformScale,\n transformTranslate,\n lineOffset,\n polygonize,\n bearingToAngle,\n featureReduce,\n geomReduce,\n booleanWithin,\n booleanDisjoint,\n booleanContains,\n booleanCrosses,\n booleanClockwise,\n booleanEqual,\n clone,\n segmentEach,\n segmentReduce,\n cleanCoords,\n isNumber,\n pointToLineDistance, // v4.7.0\n helpers,\n meta,\n invariant,\n lineEach, // v4.7.0\n lineReduce // v4.7.0\n};\n","var circle = require('@turf/circle');\nvar coordEach = require('@turf/meta').coordEach;\nvar helpers = require('@turf/helpers');\nvar getCoords = require('@turf/invariant').getCoords;\nvar polygon = helpers.polygon;\nvar lineArc = require('@turf/line-arc');\n\n/**\n * Creates a circular sector of a circle of given radius and center {@link Point},\n * between (clockwise) bearing1 and bearing2; 0 bearing is North of center point, positive clockwise.\n *\n * @name sector\n * @param {Feature} center center point\n * @param {number} radius radius of the circle\n * @param {number} bearing1 angle, in decimal degrees, of the first radius of the sector\n * @param {number} bearing2 angle, in decimal degrees, of the second radius of the sector\n * @param {number} [steps=64] number of steps\n * @param {string} [units=kilometers] miles, kilometers, degrees, or radians\n * @returns {Feature} sector polygon\n * @example\n * var center = turf.point([-75, 40]);\n * var radius = 5;\n * var bearing1 = 25;\n * var bearing2 = 45;\n *\n * var sector = turf.sector(center, radius, bearing1, bearing2);\n *\n * //addToMap\n * var addToMap = [center, sector];\n */\nmodule.exports = function (center, radius, bearing1, bearing2, steps, units) {\n // validation\n if (!center) throw new Error('center is required');\n if (bearing1 === undefined || bearing1 === null) throw new Error('bearing1 is required');\n if (bearing2 === undefined || bearing2 === null) throw new Error('bearing2 is required');\n if (!radius) throw new Error('radius is required');\n\n // default params\n steps = steps || 64;\n\n if (convertAngleTo360(bearing1) === convertAngleTo360(bearing2)) {\n return circle(center, radius, steps, units);\n }\n var coords = getCoords(center);\n var arc = lineArc(center, radius, bearing1, bearing2, steps, units);\n var sliceCoords = [[coords]];\n coordEach(arc, function (currentCoords) {\n sliceCoords[0].push(currentCoords);\n });\n sliceCoords[0].push(coords);\n\n return polygon(sliceCoords);\n};\n\n/**\n * Takes any angle in degrees\n * and returns a valid angle between 0-360 degrees\n *\n * @private\n * @param {number} alfa angle between -180-180 degrees\n * @returns {number} angle between 0-360 degrees\n */\nfunction convertAngleTo360(alfa) {\n var beta = alfa % 360;\n if (beta < 0) {\n beta += 360;\n }\n return beta;\n}\n","import mod from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SimpleTable.vue?vue&type=style&index=0&id=2728a880&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SimpleTable.vue?vue&type=style&index=0&id=2728a880&lang=scss&scoped=true&\"","'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('@turf/helpers'),\n lineString = _require.lineString,\n _require2 = require('./util'),\n orientationIndex = _require2.orientationIndex;\n\n/** This class is inspired by GEOS's geos::operation::polygonize::PolygonizeDirectedEdge\n */\n\n\nvar Edge = function () {\n _createClass(Edge, [{\n key: 'getSymetric',\n\n /** Creates or get the symetric Edge.\n *\n * @returns {Edge} - Symetric Edge.\n */\n value: function getSymetric() {\n if (!this.symetric) {\n this.symetric = new Edge(this.to, this.from);\n this.symetric.symetric = this;\n }\n\n return this.symetric;\n }\n\n /**\n * @param {Node} from - start node of the Edge\n * @param {Node} to - end node of the edge\n */\n\n }]);\n\n function Edge(from, to) {\n _classCallCheck(this, Edge);\n\n this.from = from; //< start\n this.to = to; //< End\n\n this.next = undefined; //< The edge to be computed after\n this.label = undefined; //< Used in order to detect Cut Edges (Bridges)\n this.symetric = undefined; //< The symetric edge of this\n this.ring = undefined; //< EdgeRing in which the Edge is\n\n this.from.addOuterEdge(this);\n this.to.addInnerEdge(this);\n }\n\n /** Removes edge from from and to nodes.\n */\n\n\n _createClass(Edge, [{\n key: 'deleteEdge',\n value: function deleteEdge() {\n this.from.removeOuterEdge(this);\n this.to.removeInnerEdge(this);\n }\n\n /** Compares Edge equallity.\n * An edge is equal to another, if the from and to nodes are the same.\n *\n * @param {Edge} edge - Another Edge\n * @returns {Boolean} - True if Edges are equal, False otherwise\n */\n\n }, {\n key: 'isEqual',\n value: function isEqual(edge) {\n return this.from.id === edge.from.id && this.to.id === edge.to.id;\n }\n }, {\n key: 'toString',\n value: function toString() {\n return 'Edge { ' + this.from.id + ' -> ' + this.to.id + ' }';\n }\n\n /** Returns a LineString representation of the Edge\n *\n * @returns {Feature} - LineString representation of the Edge\n */\n\n }, {\n key: 'toLineString',\n value: function toLineString() {\n return lineString([this.from.coordinates, this.to.coordinates]);\n }\n\n /** Comparator of two edges.\n * Implementation of geos::planargraph::DirectedEdge::compareTo.\n *\n * @param {Edge} edge - Another edge to compare with this one\n * @returns {Number} -1 if this Edge has a greater angle with the positive x-axis than b,\n * 0 if the Edges are colinear,\n * 1 otherwise\n */\n\n }, {\n key: 'compareTo',\n value: function compareTo(edge) {\n return orientationIndex(edge.from.coordinates, edge.to.coordinates, this.to.coordinates);\n }\n }]);\n\n return Edge;\n}();\n\nmodule.exports = Edge;","var bbox = require('@turf/bbox');\nvar area = require('@turf/area');\nvar inside = require('@turf/inside');\nvar helpers = require('@turf/helpers');\nvar explode = require('@turf/explode');\nvar invariant = require('@turf/invariant');\nvar gridToMatrix = require('grid-to-matrix');\nvar marchingsquares = require('marchingsquares');\nvar polygon = helpers.polygon;\nvar multiPolygon = helpers.multiPolygon;\nvar collectionOf = invariant.collectionOf;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Takes a grid {@link FeatureCollection} of {@link Point} features with z-values and an array of\n * value breaks and generates filled contour isobands.\n *\n * @name isobands\n * @param {FeatureCollection} pointGrid input points\n * @param {Array} breaks where to draw contours\n * @param {string} [zProperty='elevation'] the property name in `points` from which z-values will be pulled\n * @param {Object} [options={}] options on output\n * @param {Array} [options.isobandProperties=[]] GeoJSON properties passed, in order, to the correspondent isoband (order defined by breaks)\n * @param {Object} [options.commonProperties={}] GeoJSON properties passed to ALL isobands\n * @returns {FeatureCollection} a FeatureCollection of {@link MultiPolygon} features representing isobands\n * @example\n * // create a grid of points with random z-values in their properties\n * var extent = [-70.823364, -33.553984, -69.823364, -32.553984];\n * var cellWidth = 5;\n * var units = 'miles';\n * var pointGrid = turf.pointGrid(extent, cellWidth, units);\n * for (var i = 0; i < pointGrid.features.length; i++) {\n * pointGrid.features[i].properties.elevation = Math.random() * 10;\n * }\n * var breaks = [0, 5, 8.5];\n *\n * var isobands = turf.isobands(pointGrid, breaks);\n *\n * //addToMap\n * var addToMap = [isobands];\n */\nmodule.exports = function (pointGrid, breaks, zProperty, options) {\n // Input validation\n var isObject = function (input) {\n return (!!input) && (input.constructor === Object);\n };\n collectionOf(pointGrid, 'Point', 'Input must contain Points');\n if (!breaks || !Array.isArray(breaks)) throw new Error('breaks is required');\n options = options || {};\n if (options.commonProperties && !isObject(options.commonProperties)) {\n throw new Error('commonProperties is not an Object');\n }\n if (options.isobandProperties && !Array.isArray(options.isobandProperties)) {\n throw new Error('isobandProperties is not an Array');\n }\n if (zProperty && typeof zProperty !== 'string') { throw new Error('zProperty is not a string'); }\n\n zProperty = zProperty || 'elevation';\n var commonProperties = options.commonProperties || {};\n var isobandProperties = options.isobandProperties || [];\n\n // Isoband methods\n var matrix = gridToMatrix(pointGrid, zProperty, true);\n var contours = createContourLines(matrix, breaks, zProperty);\n contours = rescaleContours(contours, matrix, pointGrid);\n\n var multipolygons = contours.map(function (contour, index) {\n if (isobandProperties[index] && !isObject(isobandProperties[index])) {\n throw new Error('Each mappedProperty is required to be an Object');\n }\n // collect all properties\n var contourProperties = Object.assign(\n {},\n commonProperties,\n isobandProperties[index]\n );\n contourProperties[zProperty] = contour[zProperty];\n var multiP = multiPolygon(contour.groupedRings, contourProperties);\n return multiP;\n });\n\n return featureCollection(multipolygons);\n};\n\n/**\n * Creates the contours lines (featuresCollection of polygon features) from the 2D data grid\n *\n * Marchingsquares process the grid data as a 3D representation of a function on a 2D plane, therefore it\n * assumes the points (x-y coordinates) are one 'unit' distance. The result of the IsoBands function needs to be\n * rescaled, with turfjs, to the original area and proportions on the map\n *\n * @private\n * @param {Array>} matrix Grid Data\n * @param {Array} breaks Breaks\n * @param {string} [property='elevation'] Property\n * @returns {Array} contours\n */\nfunction createContourLines(matrix, breaks, property) {\n\n var contours = [];\n for (var i = 1; i < breaks.length; i++) {\n var lowerBand = +breaks[i - 1]; // make sure the breaks value is a number\n var upperBand = +breaks[i];\n\n var isobandsCoords = marchingsquares.isoBands(matrix, lowerBand, upperBand - lowerBand);\n // as per GeoJson rules for creating a Polygon, make sure the first element\n // in the array of LinearRings represents the exterior ring (i.e. biggest area),\n // and any subsequent elements represent interior rings (i.e. smaller area);\n // this avoids rendering issues of the MultiPolygons on the map\n var nestedRings = orderByArea(isobandsCoords);\n var groupedRings = groupNestedRings(nestedRings);\n var obj = {};\n obj['groupedRings'] = groupedRings;\n obj[property] = lowerBand + '-' + upperBand;\n contours.push(obj);\n }\n return contours;\n}\n\n/**\n * Transform isobands of 2D grid to polygons for the map\n *\n * @private\n * @param {Array} contours Contours\n * @param {Array>} matrix Grid Data\n * @param {Object} points Points by Latitude\n * @returns {Array} contours\n */\nfunction rescaleContours(contours, matrix, points) {\n\n // get dimensions (on the map) of the original grid\n var gridBbox = bbox(points); // [ minX, minY, maxX, maxY ]\n var originalWidth = gridBbox[2] - gridBbox[0];\n var originalHeigth = gridBbox[3] - gridBbox[1];\n\n // get origin, which is the first point of the last row on the rectangular data on the map\n var x0 = gridBbox[0];\n var y0 = gridBbox[1];\n // get number of cells per side\n var matrixWidth = matrix[0].length - 1;\n var matrixHeight = matrix.length - 1;\n // calculate the scaling factor between matrix and rectangular grid on the map\n var scaleX = originalWidth / matrixWidth;\n var scaleY = originalHeigth / matrixHeight;\n\n var resize = function (point) {\n point[0] = point[0] * scaleX + x0;\n point[1] = point[1] * scaleY + y0;\n };\n\n // resize and shift each point/line of the isobands\n contours.forEach(function (contour) {\n contour.groupedRings.forEach(function (lineRingSet) {\n lineRingSet.forEach(function (lineRing) {\n lineRing.forEach(resize);\n });\n });\n });\n return contours;\n}\n\n\n/* utility functions */\n\n\n/**\n * Returns an array of coordinates (of LinearRings) in descending order by area\n *\n * @private\n * @param {Array} ringsCoords array of closed LineString\n * @returns {Array} array of the input LineString ordered by area\n */\nfunction orderByArea(ringsCoords) {\n var ringsWithArea = [];\n var areas = [];\n ringsCoords.forEach(function (coords) {\n // var poly = polygon([points]);\n var ringArea = area(polygon([coords]));\n // create an array of areas value\n areas.push(ringArea);\n // associate each lineRing with its area\n ringsWithArea.push({ring: coords, area: ringArea});\n });\n areas.sort(function (a, b) { // bigger --> smaller\n return b - a;\n });\n // create a new array of linearRings coordinates ordered by their area\n var orderedByArea = [];\n areas.forEach(function (area) {\n for (var lr = 0; lr < ringsWithArea.length; lr++) {\n if (ringsWithArea[lr].area === area) {\n orderedByArea.push(ringsWithArea[lr].ring);\n ringsWithArea.splice(lr, 1);\n break;\n }\n }\n });\n return orderedByArea;\n}\n\n/**\n * Returns an array of arrays of coordinates, each representing\n * a set of (coordinates of) nested LinearRings,\n * i.e. the first ring contains all the others\n *\n * @private\n * @param {Array} orderedLinearRings array of coordinates (of LinearRings) in descending order by area\n * @returns {Array} Array of coordinates of nested LinearRings\n */\nfunction groupNestedRings(orderedLinearRings) {\n // create a list of the (coordinates of) LinearRings\n var lrList = orderedLinearRings.map(function (lr) {\n return {lrCoordinates: lr, grouped: false};\n });\n var groupedLinearRingsCoords = [];\n while (!allGrouped(lrList)) {\n for (var i = 0; i < lrList.length; i++) {\n if (!lrList[i].grouped) {\n // create new group starting with the larger not already grouped ring\n var group = [];\n group.push(lrList[i].lrCoordinates);\n lrList[i].grouped = true;\n var outerMostPoly = polygon([lrList[i].lrCoordinates]);\n // group all the rings contained by the outermost ring\n for (var j = i + 1; j < lrList.length; j++) {\n if (!lrList[j].grouped) {\n var lrPoly = polygon([lrList[j].lrCoordinates]);\n if (isInside(lrPoly, outerMostPoly)) {\n group.push(lrList[j].lrCoordinates);\n lrList[j].grouped = true;\n }\n }\n }\n // insert the new group\n groupedLinearRingsCoords.push(group);\n }\n }\n }\n return groupedLinearRingsCoords;\n}\n\n/**\n * @private\n * @param {Polygon} testPolygon polygon of interest\n * @param {Polygon} targetPolygon polygon you want to compare with\n * @returns {boolean} true if test-Polygon is inside target-Polygon\n */\nfunction isInside(testPolygon, targetPolygon) {\n var points = explode(testPolygon);\n for (var i = 0; i < points.features.length; i++) {\n if (!inside(points.features[i], targetPolygon)) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * @private\n * @param {Array} list list of objects which might contain the 'group' attribute\n * @returns {boolean} true if all the objects in the list are marked as grouped\n */\nfunction allGrouped(list) {\n for (var i = 0; i < list.length; i++) {\n if (list[i].grouped === false) {\n return false;\n }\n }\n return true;\n}\n","'use strict'\n\nmodule.exports = monotoneConvexHull2D\n\nvar orient = require('robust-orientation')[3]\n\nfunction monotoneConvexHull2D(points) {\n var n = points.length\n\n if(n < 3) {\n var result = new Array(n)\n for(var i=0; i 1 && orient(\n points[lower[m-2]], \n points[lower[m-1]], \n p) <= 0) {\n m -= 1\n lower.pop()\n }\n lower.push(idx)\n\n //Insert into upper list\n m = upper.length\n while(m > 1 && orient(\n points[upper[m-2]], \n points[upper[m-1]], \n p) >= 0) {\n m -= 1\n upper.pop()\n }\n upper.push(idx)\n }\n\n //Merge lists together\n var result = new Array(upper.length + lower.length - 2)\n var ptr = 0\n for(var i=0, nl=lower.length; i0; --j) {\n result[ptr++] = upper[j]\n }\n\n //Return result\n return result\n}","'use strict'\n\nmodule.exports = convexHullnD\n\nvar ich = require('incremental-convex-hull')\nvar aff = require('affine-hull')\n\nfunction permute(points, front) {\n var n = points.length\n var npoints = new Array(n)\n for(var i=0; i= front[k]) {\n x += 1\n }\n }\n c[j] = x\n }\n }\n }\n return cells\n}\n\nfunction convexHullnD(points, d) {\n try {\n return ich(points, true)\n } catch(e) {\n //If point set is degenerate, try to find a basis and rerun it\n var ah = aff(points)\n if(ah.length <= d) {\n //No basis, no try\n return []\n }\n var npoints = permute(points, ah)\n var nhull = ich(npoints, true)\n return invPermute(nhull, ah)\n }\n}","var meta = require('@turf/meta');\nvar equal = require('deep-equal');\nvar rbush = require('geojson-rbush');\nvar invariant = require('@turf/invariant');\nvar lineSegment = require('@turf/line-segment');\nvar pointOnLine = require('@turf/point-on-line');\nvar booleanPointOnLine = require('@turf/boolean-point-on-line');\nvar featureCollection = require('@turf/helpers').featureCollection;\nvar getCoords = invariant.getCoords;\nvar featureEach = meta.featureEach;\nvar segmentEach = meta.segmentEach;\n\n/**\n * Takes any LineString or Polygon and returns the overlapping lines between both features.\n *\n * @name lineOverlap\n * @param {Geometry|Feature} line1 any LineString or Polygon\n * @param {Geometry|Feature} line2 any LineString or Polygon\n * @param {number} [tolerance=0] Tolerance distance to match overlapping line segments (in kilometers)\n * @returns {FeatureCollection} lines(s) that are overlapping between both features\n * @example\n * var line1 = turf.lineString([[115, -35], [125, -30], [135, -30], [145, -35]]);\n * var line2 = turf.lineString([[115, -25], [125, -30], [135, -30], [145, -25]]);\n *\n * var overlapping = turf.lineOverlap(line1, line2);\n *\n * //addToMap\n * var addToMap = [line1, line2, overlapping]\n */\nmodule.exports = function (line1, line2, tolerance) {\n var features = [];\n tolerance = tolerance || 0;\n\n // Create Spatial Index\n var tree = rbush();\n tree.load(lineSegment(line1));\n var overlapSegment;\n\n // Line Intersection\n\n // Iterate over line segments\n segmentEach(line2, function (segment) {\n var doesOverlaps = false;\n\n // Iterate over each segments which falls within the same bounds\n featureEach(tree.search(segment), function (match) {\n if (doesOverlaps === false) {\n var coordsSegment = getCoords(segment).sort();\n var coordsMatch = getCoords(match).sort();\n\n // Segment overlaps feature\n if (equal(coordsSegment, coordsMatch)) {\n doesOverlaps = true;\n // Overlaps already exists - only append last coordinate of segment\n if (overlapSegment) overlapSegment = concatSegment(overlapSegment, segment);\n else overlapSegment = segment;\n // Match segments which don't share nodes (Issue #901)\n } else if (\n (tolerance === 0) ?\n booleanPointOnLine(coordsSegment[0], match) && booleanPointOnLine(coordsSegment[1], match) :\n pointOnLine(match, coordsSegment[0]).properties.dist <= tolerance &&\n pointOnLine(match, coordsSegment[1]).properties.dist <= tolerance) {\n doesOverlaps = true;\n if (overlapSegment) overlapSegment = concatSegment(overlapSegment, segment);\n else overlapSegment = segment;\n } else if (\n (tolerance === 0) ?\n booleanPointOnLine(coordsMatch[0], segment) && booleanPointOnLine(coordsMatch[1], segment) :\n pointOnLine(segment, coordsMatch[0]).properties.dist <= tolerance &&\n pointOnLine(segment, coordsMatch[1]).properties.dist <= tolerance) {\n // Do not define (doesOverlap = true) since more matches can occur within the same segment\n // doesOverlaps = true;\n if (overlapSegment) overlapSegment = concatSegment(overlapSegment, match);\n else overlapSegment = match;\n }\n }\n });\n\n // Segment doesn't overlap - add overlaps to results & reset\n if (doesOverlaps === false && overlapSegment) {\n features.push(overlapSegment);\n overlapSegment = undefined;\n }\n });\n // Add last segment if exists\n if (overlapSegment) features.push(overlapSegment);\n\n return featureCollection(features);\n};\n\n\n/**\n * Concat Segment\n *\n * @private\n * @param {Feature} line LineString\n * @param {Feature} segment 2-vertex LineString\n * @returns {Feature} concat linestring\n */\nfunction concatSegment(line, segment) {\n var coords = getCoords(segment);\n var lineCoords = getCoords(line);\n var start = lineCoords[0];\n var end = lineCoords[lineCoords.length - 1];\n var geom = line.geometry.coordinates;\n\n if (equal(coords[0], start)) geom.unshift(coords[1]);\n else if (equal(coords[0], end)) geom.push(coords[1]);\n else if (equal(coords[1], start)) geom.unshift(coords[0]);\n else if (equal(coords[1], end)) geom.push(coords[0]);\n return line;\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('LabelAndMessage',{attrs:{\"required\":_vm.required,\"label\":_vm.label,\"feedback-classes\":_vm.feedbackClasses,\"description\":_vm.combinedDescription,\"message\":_vm.message}},[_c('div',{staticClass:\"vue-selectize\"},[_c('select',{ref:\"select\",attrs:{\"name\":_vm.name}})]),_vm._t(\"label\",null,{\"slot\":\"label\"}),_vm._t(\"description\",null,{\"slot\":\"description\"})],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","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!./VueSelectize.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!./VueSelectize.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./VueSelectize.vue?vue&type=template&id=10288aca&scoped=true&lang=html&\"\nimport script from \"./VueSelectize.vue?vue&type=script&lang=js&\"\nexport * from \"./VueSelectize.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 \"10288aca\",\n null\n \n)\n\nexport default component.exports","var render = function () {\nvar _obj;\nvar _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"panel list-card\",class:( _obj = {selected: _vm.selected, 'partially-selected': _vm.selected === null}, _obj[_vm.panelClass] = _vm.panelClass, _obj )},[_c('div',{staticClass:\"panel-body\"},[_c('div',{staticClass:\"list-card-header\"},[(_vm.showAvatar)?_c('div',{staticClass:\"list-card-avatar\"},[_vm._t(\"avatar\")],2):_vm._e(),_c('div',{staticClass:\"default-header\"},[_c('span',{staticClass:\"title\",attrs:{\"title\":_vm.titleTranslate ? _vm.$i18n.translate(_vm.title) : _vm.title}},[(_vm.locked)?_c('i',{staticClass:\"fa fa-lock\"}):_vm._e(),(_vm.titleTranslate)?_c('IxRes',[_vm._v(_vm._s(_vm.title))]):_vm._t(\"title\",[_c('span',[_vm._v(_vm._s(_vm.title))])])],2),_c('span',{staticClass:\"subtitle\",attrs:{\"title\":_vm.subtitle}},[_vm._t(\"subtitle\",[(!_vm.subtitleTranslate)?_c('span',[_vm._v(_vm._s(_vm.subtitle))]):_c('IxRes',[_vm._v(_vm._s(_vm.subtitle))])])],2)]),_c('div',{staticClass:\"header\"},[_vm._t(\"header\")],2),_c('div',{staticClass:\"addon\"},[_vm._t(\"addon\")],2)]),_vm._t(\"tags\"),(_vm.showDetails)?_vm._t(\"default\"):_vm._e()],2),(_vm.$slots.bottom)?_c('div',{staticClass:\"bottom\"},[_vm._t(\"bottom\")],2):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./ListCard.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!./ListCard.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ListCard.vue?vue&type=template&id=234b201c&scoped=true&lang=html&\"\nimport script from \"./ListCard.vue?vue&type=script&lang=js&\"\nexport * from \"./ListCard.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ListCard.vue?vue&type=style&index=0&id=234b201c&lang=scss&scoped=true&\"\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 \"234b201c\",\n null\n \n)\n\nexport default component.exports","\"use strict\"\n\nmodule.exports = fastTwoSum\n\nfunction fastTwoSum(a, b, result) {\n\tvar x = a + b\n\tvar bv = x - a\n\tvar av = x - bv\n\tvar br = b - bv\n\tvar ar = a - av\n\tif(result) {\n\t\tresult[0] = ar + br\n\t\tresult[1] = x\n\t\treturn result\n\t}\n\treturn [ar+br, x]\n}","var helpers = require('@turf/helpers');\nvar invariant = require('@turf/invariant');\nvar getCoords = invariant.getCoords;\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Removes redundant coordinates from any GeoJSON Geometry.\n *\n * @name cleanCoords\n * @param {Geometry|Feature} geojson Feature or Geometry\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated\n * @returns {Geometry|Feature} the cleaned input Feature/Geometry\n * @example\n * var line = turf.lineString([[0, 0], [0, 2], [0, 5], [0, 8], [0, 8], [0, 10]]);\n * var multiPoint = turf.multiPoint([[0, 0], [0, 0], [2, 2]]);\n *\n * turf.cleanCoords(line).geometry.coordinates;\n * //= [[0, 0], [0, 10]]\n *\n * turf.cleanCoords(multiPoint).geometry.coordinates;\n * //= [[0, 0], [2, 2]]\n */\nmodule.exports = function (geojson, mutate) {\n if (!geojson) throw new Error('geojson is required');\n var type = getGeomType(geojson);\n\n // Store new \"clean\" points in this Array\n var newCoords = [];\n\n switch (type) {\n case 'LineString':\n newCoords = cleanCoords(geojson);\n break;\n case 'MultiLineString':\n case 'Polygon':\n getCoords(geojson).forEach(function (line) {\n newCoords.push(cleanCoords(line));\n });\n break;\n case 'MultiPolygon':\n getCoords(geojson).forEach(function (polygons) {\n var polyPoints = [];\n polygons.forEach(function (ring) {\n polyPoints.push(cleanCoords(ring));\n });\n newCoords.push(polyPoints);\n });\n break;\n case 'Point':\n return geojson;\n case 'MultiPoint':\n var existing = {};\n getCoords(geojson).forEach(function (coord) {\n var key = coord.join('-');\n if (!existing.hasOwnProperty(key)) {\n newCoords.push(coord);\n existing[key] = true;\n }\n });\n break;\n default:\n throw new Error(type + ' geometry not supported');\n }\n\n // Support input mutation\n if (geojson.coordinates) {\n if (mutate === true) {\n geojson.coordinates = newCoords;\n return geojson;\n }\n return geometry(geojson, type, newCoords);\n } else {\n if (mutate === true) {\n geojson.geometry.coordinates = newCoords;\n return geojson;\n }\n return feature(geojson, type, newCoords);\n }\n};\n\n/**\n * Create Geometry from existing Geometry\n *\n * @private\n * @param {Geometry} geojson Existing Geometry\n * @param {string} type Geometry Type\n * @param {Array} coordinates Coordinates\n * @returns {Geometry} Geometry\n */\nfunction geometry(geojson, type, coordinates) {\n var geom = {\n type: type,\n coordinates: coordinates\n };\n if (geojson.bbox) geom.bbox = geojson.bbox;\n return geom;\n}\n\n/**\n * Create Feature from existing Feature\n *\n * @private\n * @param {Feature} geojson Existing Feature\n * @param {string} type Feature Type\n * @param {Array} coordinates Coordinates\n * @returns {Feature} Feature\n */\nfunction feature(geojson, type, coordinates) {\n var feat = helpers.feature(geometry(geojson.geometry, type, coordinates), geojson.properties);\n if (geojson.id) feat.id = geojson.id;\n if (geojson.bbox) feat.bbox = geojson.bbox;\n return feat;\n}\n\n/**\n * Clean Coords\n *\n * @private\n * @param {Array|LineString} line Line\n * @returns {Array} Cleaned coordinates\n */\nfunction cleanCoords(line) {\n var points = getCoords(line);\n // handle \"clean\" segment\n if (points.length === 2 && !equals(points[0], points[1])) return points;\n\n var prevPoint, point, nextPoint;\n var newPoints = [];\n var secondToLast = points.length - 1;\n\n newPoints.push(points[0]);\n for (var i = 1; i < secondToLast; i++) {\n prevPoint = points[i - 1];\n point = points[i];\n nextPoint = points[i + 1];\n\n if (!isPointOnLineSegment(prevPoint, nextPoint, point)) {\n newPoints.push(point);\n }\n }\n newPoints.push(nextPoint);\n return newPoints;\n}\n\n/**\n * Compares two points and returns if they are equals\n *\n * @private\n * @param {Array} pt1 point\n * @param {Array} pt2 point\n * @returns {boolean} true if they are equals\n */\nfunction equals(pt1, pt2) {\n return pt1[0] === pt2[0] && pt1[1] === pt2[1];\n}\n\n/**\n * Returns if `point` is on the segment between `start` and `end`.\n * Borrowed from `@turf/boolean-point-on-line` to speed up the evaluation (instead of using the module as dependency)\n *\n * @private\n * @param {Array} start coord pair of start of line\n * @param {Array} end coord pair of end of line\n * @param {Array} point coord pair of point to check\n * @returns {boolean} true/false\n */\nfunction isPointOnLineSegment(start, end, point) {\n var x = point[0], y = point[1];\n var startX = start[0], startY = start[1];\n var endX = end[0], endY = end[1];\n\n var dxc = x - startX;\n var dyc = y - startY;\n var dxl = endX - startX;\n var dyl = endY - startY;\n var cross = dxc * dyl - dyc * dxl;\n\n if (cross !== 0) return false;\n else if (Math.abs(dxl) >= Math.abs(dyl)) return dxl > 0 ? startX <= x && x <= endX : endX <= x && x <= startX;\n else return dyl > 0 ? startY <= y && y <= endY : endY <= y && y <= startY;\n}\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n/* Latitude/longitude spherical geodesy tools (c) Chris Veness 2002-2017 */\n/* MIT Licence */\n/* www.movable-type.co.uk/scripts/latlong.html */\n/* www.movable-type.co.uk/scripts/geodesy/docs/module-latlon-spherical.html */\n/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n'use strict';\nif (typeof module!='undefined' && module.exports) var Dms = require('./dms'); // ≡ import Dms from 'dms.js'\n\n\n/**\n * Library of geodesy functions for operations on a spherical earth model.\n *\n * @module latlon-spherical\n * @requires dms\n */\n\n\n/**\n * Creates a LatLon point on the earth's surface at the specified latitude / longitude.\n *\n * @constructor\n * @param {number} lat - Latitude in degrees.\n * @param {number} lon - Longitude in degrees.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n */\nfunction LatLon(lat, lon) {\n // allow instantiation without 'new'\n if (!(this instanceof LatLon)) return new LatLon(lat, lon);\n\n this.lat = Number(lat);\n this.lon = Number(lon);\n}\n\n\n/**\n * Returns the distance from ‘this’ point to destination point (using haversine formula).\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance between this point and destination point, in same units as radius.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var d = p1.distanceTo(p2); // 404.3 km\n */\nLatLon.prototype.distanceTo = function(point, radius) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n // a = sin²(Δφ/2) + cos(φ1)⋅cos(φ2)⋅sin²(Δλ/2)\n // tanδ = √(a) / √(1−a)\n // see mathforum.org/library/drmath/view/51879.html for derivation\n\n var R = radius;\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var φ2 = point.lat.toRadians(), λ2 = point.lon.toRadians();\n var Δφ = φ2 - φ1;\n var Δλ = λ2 - λ1;\n\n var a = Math.sin(Δφ/2) * Math.sin(Δφ/2)\n + Math.cos(φ1) * Math.cos(φ2)\n * Math.sin(Δλ/2) * Math.sin(Δλ/2);\n var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));\n var d = R * c;\n\n return d;\n};\n\n\n/**\n * Returns the (initial) bearing from ‘this’ point to destination point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} Initial bearing in degrees from north.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var b1 = p1.bearingTo(p2); // 156.2°\n */\nLatLon.prototype.bearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // tanθ = sinΔλ⋅cosφ2 / cosφ1⋅sinφ2 − sinφ1⋅cosφ2⋅cosΔλ\n // see mathforum.org/library/drmath/view/55417.html for derivation\n\n var φ1 = this.lat.toRadians(), φ2 = point.lat.toRadians();\n var Δλ = (point.lon-this.lon).toRadians();\n var y = Math.sin(Δλ) * Math.cos(φ2);\n var x = Math.cos(φ1)*Math.sin(φ2) -\n Math.sin(φ1)*Math.cos(φ2)*Math.cos(Δλ);\n var θ = Math.atan2(y, x);\n\n return (θ.toDegrees()+360) % 360;\n};\n\n\n/**\n * Returns final bearing arriving at destination destination point from ‘this’ point; the final bearing\n * will differ from the initial bearing by varying degrees according to distance and latitude.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} Final bearing in degrees from north.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var b2 = p1.finalBearingTo(p2); // 157.9°\n */\nLatLon.prototype.finalBearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // get initial bearing from destination point to this point & reverse it by adding 180°\n return ( point.bearingTo(this)+180 ) % 360;\n};\n\n\n/**\n * Returns the midpoint between ‘this’ point and the supplied point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {LatLon} Midpoint between this point and the supplied point.\n *\n * @example\n * var p1 = new LatLon(52.205, 0.119);\n * var p2 = new LatLon(48.857, 2.351);\n * var pMid = p1.midpointTo(p2); // 50.5363°N, 001.2746°E\n */\nLatLon.prototype.midpointTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // φm = atan2( sinφ1 + sinφ2, √( (cosφ1 + cosφ2⋅cosΔλ) ⋅ (cosφ1 + cosφ2⋅cosΔλ) ) + cos²φ2⋅sin²Δλ )\n // λm = λ1 + atan2(cosφ2⋅sinΔλ, cosφ1 + cosφ2⋅cosΔλ)\n // see mathforum.org/library/drmath/view/51822.html for derivation\n\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var φ2 = point.lat.toRadians();\n var Δλ = (point.lon-this.lon).toRadians();\n\n var Bx = Math.cos(φ2) * Math.cos(Δλ);\n var By = Math.cos(φ2) * Math.sin(Δλ);\n\n var x = Math.sqrt((Math.cos(φ1) + Bx) * (Math.cos(φ1) + Bx) + By * By);\n var y = Math.sin(φ1) + Math.sin(φ2);\n var φ3 = Math.atan2(y, x);\n\n var λ3 = λ1 + Math.atan2(By, Math.cos(φ1) + Bx);\n\n return new LatLon(φ3.toDegrees(), (λ3.toDegrees()+540)%360-180); // normalise to −180..+180°\n};\n\n\n/**\n * Returns the point at given fraction between ‘this’ point and specified point.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} fraction - Fraction between the two points (0 = this point, 1 = specified point).\n * @returns {LatLon} Intermediate point between this point and destination point.\n *\n * @example\n * let p1 = new LatLon(52.205, 0.119);\n * let p2 = new LatLon(48.857, 2.351);\n * let pMid = p1.intermediatePointTo(p2, 0.25); // 51.3721°N, 000.7073°E\n */\nLatLon.prototype.intermediatePointTo = function(point, fraction) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var φ2 = point.lat.toRadians(), λ2 = point.lon.toRadians();\n var sinφ1 = Math.sin(φ1), cosφ1 = Math.cos(φ1), sinλ1 = Math.sin(λ1), cosλ1 = Math.cos(λ1);\n var sinφ2 = Math.sin(φ2), cosφ2 = Math.cos(φ2), sinλ2 = Math.sin(λ2), cosλ2 = Math.cos(λ2);\n\n // distance between points\n var Δφ = φ2 - φ1;\n var Δλ = λ2 - λ1;\n var a = Math.sin(Δφ/2) * Math.sin(Δφ/2)\n + Math.cos(φ1) * Math.cos(φ2) * Math.sin(Δλ/2) * Math.sin(Δλ/2);\n var δ = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));\n\n var A = Math.sin((1-fraction)*δ) / Math.sin(δ);\n var B = Math.sin(fraction*δ) / Math.sin(δ);\n\n var x = A * cosφ1 * cosλ1 + B * cosφ2 * cosλ2;\n var y = A * cosφ1 * sinλ1 + B * cosφ2 * sinλ2;\n var z = A * sinφ1 + B * sinφ2;\n\n var φ3 = Math.atan2(z, Math.sqrt(x*x + y*y));\n var λ3 = Math.atan2(y, x);\n\n return new LatLon(φ3.toDegrees(), (λ3.toDegrees()+540)%360-180); // normalise lon to −180..+180°\n};\n\n\n/**\n * Returns the destination point from ‘this’ point having travelled the given distance on the\n * given initial bearing (bearing normally varies around path followed).\n *\n * @param {number} distance - Distance travelled, in same units as earth radius (default: metres).\n * @param {number} bearing - Initial bearing in degrees from north.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {LatLon} Destination point.\n *\n * @example\n * var p1 = new LatLon(51.4778, -0.0015);\n * var p2 = p1.destinationPoint(7794, 300.7); // 51.5135°N, 000.0983°W\n */\nLatLon.prototype.destinationPoint = function(distance, bearing, radius) {\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n // sinφ2 = sinφ1⋅cosδ + cosφ1⋅sinδ⋅cosθ\n // tanΔλ = sinθ⋅sinδ⋅cosφ1 / cosδ−sinφ1⋅sinφ2\n // see mathforum.org/library/drmath/view/52049.html for derivation\n\n var δ = Number(distance) / radius; // angular distance in radians\n var θ = Number(bearing).toRadians();\n\n var φ1 = this.lat.toRadians();\n var λ1 = this.lon.toRadians();\n\n var sinφ1 = Math.sin(φ1), cosφ1 = Math.cos(φ1);\n var sinδ = Math.sin(δ), cosδ = Math.cos(δ);\n var sinθ = Math.sin(θ), cosθ = Math.cos(θ);\n\n var sinφ2 = sinφ1*cosδ + cosφ1*sinδ*cosθ;\n var φ2 = Math.asin(sinφ2);\n var y = sinθ * sinδ * cosφ1;\n var x = cosδ - sinφ1 * sinφ2;\n var λ2 = λ1 + Math.atan2(y, x);\n\n return new LatLon(φ2.toDegrees(), (λ2.toDegrees()+540)%360-180); // normalise to −180..+180°\n};\n\n\n/**\n * Returns the point of intersection of two paths defined by point and bearing.\n *\n * @param {LatLon} p1 - First point.\n * @param {number} brng1 - Initial bearing from first point.\n * @param {LatLon} p2 - Second point.\n * @param {number} brng2 - Initial bearing from second point.\n * @returns {LatLon|null} Destination point (null if no unique intersection defined).\n *\n * @example\n * var p1 = LatLon(51.8853, 0.2545), brng1 = 108.547;\n * var p2 = LatLon(49.0034, 2.5735), brng2 = 32.435;\n * var pInt = LatLon.intersection(p1, brng1, p2, brng2); // 50.9078°N, 004.5084°E\n */\nLatLon.intersection = function(p1, brng1, p2, brng2) {\n if (!(p1 instanceof LatLon)) throw new TypeError('p1 is not LatLon object');\n if (!(p2 instanceof LatLon)) throw new TypeError('p2 is not LatLon object');\n\n // see www.edwilliams.org/avform.htm#Intersection\n\n var φ1 = p1.lat.toRadians(), λ1 = p1.lon.toRadians();\n var φ2 = p2.lat.toRadians(), λ2 = p2.lon.toRadians();\n var θ13 = Number(brng1).toRadians(), θ23 = Number(brng2).toRadians();\n var Δφ = φ2-φ1, Δλ = λ2-λ1;\n\n // angular distance p1-p2\n var δ12 = 2*Math.asin( Math.sqrt( Math.sin(Δφ/2)*Math.sin(Δφ/2)\n + Math.cos(φ1)*Math.cos(φ2)*Math.sin(Δλ/2)*Math.sin(Δλ/2) ) );\n if (δ12 == 0) return null;\n\n // initial/final bearings between points\n var θa = Math.acos( ( Math.sin(φ2) - Math.sin(φ1)*Math.cos(δ12) ) / ( Math.sin(δ12)*Math.cos(φ1) ) );\n if (isNaN(θa)) θa = 0; // protect against rounding\n var θb = Math.acos( ( Math.sin(φ1) - Math.sin(φ2)*Math.cos(δ12) ) / ( Math.sin(δ12)*Math.cos(φ2) ) );\n\n var θ12 = Math.sin(λ2-λ1)>0 ? θa : 2*Math.PI-θa;\n var θ21 = Math.sin(λ2-λ1)>0 ? 2*Math.PI-θb : θb;\n\n var α1 = θ13 - θ12; // angle 2-1-3\n var α2 = θ21 - θ23; // angle 1-2-3\n\n if (Math.sin(α1)==0 && Math.sin(α2)==0) return null; // infinite intersections\n if (Math.sin(α1)*Math.sin(α2) < 0) return null; // ambiguous intersection\n\n var α3 = Math.acos( -Math.cos(α1)*Math.cos(α2) + Math.sin(α1)*Math.sin(α2)*Math.cos(δ12) );\n var δ13 = Math.atan2( Math.sin(δ12)*Math.sin(α1)*Math.sin(α2), Math.cos(α2)+Math.cos(α1)*Math.cos(α3) );\n var φ3 = Math.asin( Math.sin(φ1)*Math.cos(δ13) + Math.cos(φ1)*Math.sin(δ13)*Math.cos(θ13) );\n var Δλ13 = Math.atan2( Math.sin(θ13)*Math.sin(δ13)*Math.cos(φ1), Math.cos(δ13)-Math.sin(φ1)*Math.sin(φ3) );\n var λ3 = λ1 + Δλ13;\n\n return new LatLon(φ3.toDegrees(), (λ3.toDegrees()+540)%360-180); // normalise to −180..+180°\n};\n\n\n/**\n * Returns (signed) distance from ‘this’ point to great circle defined by start-point and end-point.\n *\n * @param {LatLon} pathStart - Start point of great circle path.\n * @param {LatLon} pathEnd - End point of great circle path.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance to great circle (-ve if to left, +ve if to right of path).\n *\n * @example\n * var pCurrent = new LatLon(53.2611, -0.7972);\n * var p1 = new LatLon(53.3206, -1.7297);\n * var p2 = new LatLon(53.1887, 0.1334);\n * var d = pCurrent.crossTrackDistanceTo(p1, p2); // -307.5 m\n */\nLatLon.prototype.crossTrackDistanceTo = function(pathStart, pathEnd, radius) {\n if (!(pathStart instanceof LatLon)) throw new TypeError('pathStart is not LatLon object');\n if (!(pathEnd instanceof LatLon)) throw new TypeError('pathEnd is not LatLon object');\n var R = (radius === undefined) ? 6371e3 : Number(radius);\n\n var δ13 = pathStart.distanceTo(this, R) / R;\n var θ13 = pathStart.bearingTo(this).toRadians();\n var θ12 = pathStart.bearingTo(pathEnd).toRadians();\n\n var δxt = Math.asin(Math.sin(δ13) * Math.sin(θ13-θ12));\n\n return δxt * R;\n};\n\n\n/**\n * Returns how far ‘this’ point is along a path from from start-point, heading towards end-point.\n * That is, if a perpendicular is drawn from ‘this’ point to the (great circle) path, the along-track\n * distance is the distance from the start point to where the perpendicular crosses the path.\n *\n * @param {LatLon} pathStart - Start point of great circle path.\n * @param {LatLon} pathEnd - End point of great circle path.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance along great circle to point nearest ‘this’ point.\n *\n * @example\n * var pCurrent = new LatLon(53.2611, -0.7972);\n * var p1 = new LatLon(53.3206, -1.7297);\n * var p2 = new LatLon(53.1887, 0.1334);\n * var d = pCurrent.alongTrackDistanceTo(p1, p2); // 62.331 km\n */\nLatLon.prototype.alongTrackDistanceTo = function(pathStart, pathEnd, radius) {\n if (!(pathStart instanceof LatLon)) throw new TypeError('pathStart is not LatLon object');\n if (!(pathEnd instanceof LatLon)) throw new TypeError('pathEnd is not LatLon object');\n var R = (radius === undefined) ? 6371e3 : Number(radius);\n\n var δ13 = pathStart.distanceTo(this, R) / R;\n var θ13 = pathStart.bearingTo(this).toRadians();\n var θ12 = pathStart.bearingTo(pathEnd).toRadians();\n\n var δxt = Math.asin(Math.sin(δ13) * Math.sin(θ13-θ12));\n\n var δat = Math.acos(Math.cos(δ13) / Math.abs(Math.cos(δxt)));\n\n return δat*Math.sign(Math.cos(θ12-θ13)) * R;\n};\n\n\n/**\n * Returns maximum latitude reached when travelling on a great circle on given bearing from this\n * point ('Clairaut's formula'). Negate the result for the minimum latitude (in the Southern\n * hemisphere).\n *\n * The maximum latitude is independent of longitude; it will be the same for all points on a given\n * latitude.\n *\n * @param {number} bearing - Initial bearing.\n * @param {number} latitude - Starting latitude.\n */\nLatLon.prototype.maxLatitude = function(bearing) {\n var θ = Number(bearing).toRadians();\n\n var φ = this.lat.toRadians();\n\n var φMax = Math.acos(Math.abs(Math.sin(θ)*Math.cos(φ)));\n\n return φMax.toDegrees();\n};\n\n\n/**\n * Returns the pair of meridians at which a great circle defined by two points crosses the given\n * latitude. If the great circle doesn't reach the given latitude, null is returned.\n *\n * @param {LatLon} point1 - First point defining great circle.\n * @param {LatLon} point2 - Second point defining great circle.\n * @param {number} latitude - Latitude crossings are to be determined for.\n * @returns {Object|null} Object containing { lon1, lon2 } or null if given latitude not reached.\n */\nLatLon.crossingParallels = function(point1, point2, latitude) {\n var φ = Number(latitude).toRadians();\n\n var φ1 = point1.lat.toRadians();\n var λ1 = point1.lon.toRadians();\n var φ2 = point2.lat.toRadians();\n var λ2 = point2.lon.toRadians();\n\n var Δλ = λ2 - λ1;\n\n var x = Math.sin(φ1) * Math.cos(φ2) * Math.cos(φ) * Math.sin(Δλ);\n var y = Math.sin(φ1) * Math.cos(φ2) * Math.cos(φ) * Math.cos(Δλ) - Math.cos(φ1) * Math.sin(φ2) * Math.cos(φ);\n var z = Math.cos(φ1) * Math.cos(φ2) * Math.sin(φ) * Math.sin(Δλ);\n\n if (z*z > x*x + y*y) return null; // great circle doesn't reach latitude\n\n var λm = Math.atan2(-y, x); // longitude at max latitude\n var Δλi = Math.acos(z / Math.sqrt(x*x+y*y)); // Δλ from λm to intersection points\n\n var λi1 = λ1 + λm - Δλi;\n var λi2 = λ1 + λm + Δλi;\n\n return { lon1: (λi1.toDegrees()+540)%360-180, lon2: (λi2.toDegrees()+540)%360-180 }; // normalise to −180..+180°\n};\n\n\n/* Rhumb - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n/**\n * Returns the distance travelling from ‘this’ point to destination point along a rhumb line.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} Distance in km between this point and destination point (same units as radius).\n *\n * @example\n * var p1 = new LatLon(51.127, 1.338);\n * var p2 = new LatLon(50.964, 1.853);\n * var d = p1.distanceTo(p2); // 40.31 km\n */\nLatLon.prototype.rhumbDistanceTo = function(point, radius) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n // see www.edwilliams.org/avform.htm#Rhumb\n\n var R = radius;\n var φ1 = this.lat.toRadians(), φ2 = point.lat.toRadians();\n var Δφ = φ2 - φ1;\n var Δλ = Math.abs(point.lon-this.lon).toRadians();\n // if dLon over 180° take shorter rhumb line across the anti-meridian:\n if (Δλ > Math.PI) Δλ -= 2*Math.PI;\n\n // on Mercator projection, longitude distances shrink by latitude; q is the 'stretch factor'\n // q becomes ill-conditioned along E-W line (0/0); use empirical tolerance to avoid it\n var Δψ = Math.log(Math.tan(φ2/2+Math.PI/4)/Math.tan(φ1/2+Math.PI/4));\n var q = Math.abs(Δψ) > 10e-12 ? Δφ/Δψ : Math.cos(φ1);\n\n // distance is pythagoras on 'stretched' Mercator projection\n var δ = Math.sqrt(Δφ*Δφ + q*q*Δλ*Δλ); // angular distance in radians\n var dist = δ * R;\n\n return dist;\n};\n\n\n/**\n * Returns the bearing from ‘this’ point to destination point along a rhumb line.\n *\n * @param {LatLon} point - Latitude/longitude of destination point.\n * @returns {number} Bearing in degrees from north.\n *\n * @example\n * var p1 = new LatLon(51.127, 1.338);\n * var p2 = new LatLon(50.964, 1.853);\n * var d = p1.rhumbBearingTo(p2); // 116.7 m\n */\nLatLon.prototype.rhumbBearingTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n var φ1 = this.lat.toRadians(), φ2 = point.lat.toRadians();\n var Δλ = (point.lon-this.lon).toRadians();\n // if dLon over 180° take shorter rhumb line across the anti-meridian:\n if (Δλ > Math.PI) Δλ -= 2*Math.PI;\n if (Δλ < -Math.PI) Δλ += 2*Math.PI;\n\n var Δψ = Math.log(Math.tan(φ2/2+Math.PI/4)/Math.tan(φ1/2+Math.PI/4));\n\n var θ = Math.atan2(Δλ, Δψ);\n\n return (θ.toDegrees()+360) % 360;\n};\n\n\n/**\n * Returns the destination point having travelled along a rhumb line from ‘this’ point the given\n * distance on the given bearing.\n *\n * @param {number} distance - Distance travelled, in same units as earth radius (default: metres).\n * @param {number} bearing - Bearing in degrees from north.\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {LatLon} Destination point.\n *\n * @example\n * var p1 = new LatLon(51.127, 1.338);\n * var p2 = p1.rhumbDestinationPoint(40300, 116.7); // 50.9642°N, 001.8530°E\n */\nLatLon.prototype.rhumbDestinationPoint = function(distance, bearing, radius) {\n radius = (radius === undefined) ? 6371e3 : Number(radius);\n\n var δ = Number(distance) / radius; // angular distance in radians\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var θ = Number(bearing).toRadians();\n\n var Δφ = δ * Math.cos(θ);\n var φ2 = φ1 + Δφ;\n\n // check for some daft bugger going past the pole, normalise latitude if so\n if (Math.abs(φ2) > Math.PI/2) φ2 = φ2>0 ? Math.PI-φ2 : -Math.PI-φ2;\n\n var Δψ = Math.log(Math.tan(φ2/2+Math.PI/4)/Math.tan(φ1/2+Math.PI/4));\n var q = Math.abs(Δψ) > 10e-12 ? Δφ / Δψ : Math.cos(φ1); // E-W course becomes ill-conditioned with 0/0\n\n var Δλ = δ*Math.sin(θ)/q;\n var λ2 = λ1 + Δλ;\n\n return new LatLon(φ2.toDegrees(), (λ2.toDegrees()+540) % 360 - 180); // normalise to −180..+180°\n};\n\n\n/**\n * Returns the loxodromic midpoint (along a rhumb line) between ‘this’ point and second point.\n *\n * @param {LatLon} point - Latitude/longitude of second point.\n * @returns {LatLon} Midpoint between this point and second point.\n *\n * @example\n * var p1 = new LatLon(51.127, 1.338);\n * var p2 = new LatLon(50.964, 1.853);\n * var pMid = p1.rhumbMidpointTo(p2); // 51.0455°N, 001.5957°E\n */\nLatLon.prototype.rhumbMidpointTo = function(point) {\n if (!(point instanceof LatLon)) throw new TypeError('point is not LatLon object');\n\n // see mathforum.org/kb/message.jspa?messageID=148837\n\n var φ1 = this.lat.toRadians(), λ1 = this.lon.toRadians();\n var φ2 = point.lat.toRadians(), λ2 = point.lon.toRadians();\n\n if (Math.abs(λ2-λ1) > Math.PI) λ1 += 2*Math.PI; // crossing anti-meridian\n\n var φ3 = (φ1+φ2)/2;\n var f1 = Math.tan(Math.PI/4 + φ1/2);\n var f2 = Math.tan(Math.PI/4 + φ2/2);\n var f3 = Math.tan(Math.PI/4 + φ3/2);\n var λ3 = ( (λ2-λ1)*Math.log(f3) + λ1*Math.log(f2) - λ2*Math.log(f1) ) / Math.log(f2/f1);\n\n if (!isFinite(λ3)) λ3 = (λ1+λ2)/2; // parallel of latitude\n\n var p = LatLon(φ3.toDegrees(), (λ3.toDegrees()+540)%360-180); // normalise to −180..+180°\n\n return p;\n};\n\n\n/* Area - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\n\n\n/**\n * Calculates the area of a spherical polygon where the sides of the polygon are great circle\n * arcs joining the vertices.\n *\n * @param {LatLon[]} polygon - Array of points defining vertices of the polygon\n * @param {number} [radius=6371e3] - (Mean) radius of earth (defaults to radius in metres).\n * @returns {number} The area of the polygon, in the same units as radius.\n *\n * @example\n * var polygon = [new LatLon(0,0), new LatLon(1,0), new LatLon(0,1)];\n * var area = LatLon.areaOf(polygon); // 6.18e9 m²\n */\nLatLon.areaOf = function(polygon, radius) {\n // uses method due to Karney: osgeo-org.1560.x6.nabble.com/Area-of-a-spherical-polygon-td3841625.html;\n // for each edge of the polygon, tan(E/2) = tan(Δλ/2)·(tan(φ1/2) + tan(φ2/2)) / (1 + tan(φ1/2)·tan(φ2/2))\n // where E is the spherical excess of the trapezium obtained by extending the edge to the equator\n\n var R = (radius === undefined) ? 6371e3 : Number(radius);\n\n // close polygon so that last point equals first point\n var closed = polygon[0].equals(polygon[polygon.length-1]);\n if (!closed) polygon.push(polygon[0]);\n\n var nVertices = polygon.length - 1;\n\n var S = 0; // spherical excess in steradians\n for (var v=0; v|Array} start starting Point\n * @param {Geometry|Feature|Array} end ending Point\n * @param {boolean} [final=false] calculates the final bearing if true\n * @returns {number} bearing from north in decimal degrees, between -180 and 180 degrees (positive clockwise)\n * @example\n * var point1 = turf.point([-75.343, 39.984], {\"marker-color\": \"#F00\"});\n * var point2 = turf.point([-75.534, 39.123], {\"marker-color\": \"#00F\"});\n *\n * var bearing = turf.rhumbBearing(point1, point2);\n *\n * //addToMap\n * var addToMap = [point1, point2]\n * point1.properties.bearing = bearing\n * point2.properties.bearing = bearing\n */\nmodule.exports = function (start, end, final) {\n // validation\n if (!start) throw new Error('start point is required');\n if (!end) throw new Error('end point is required');\n\n var coordsStart = getCoord(start);\n var coordsEnd = getCoord(end);\n var origin = new GeodesyLatLon(coordsStart[1], coordsStart[0]);\n var destination = new GeodesyLatLon(coordsEnd[1], coordsEnd[0]);\n var bear360;\n\n if (final) bear360 = destination.rhumbBearingTo(origin);\n else bear360 = origin.rhumbBearingTo(destination);\n\n var bear180 = (bear360 > 180) ? -(360 - bear360) : bear360;\n\n return bear180;\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.debug)?_c('div',{staticClass:\"wfs-map-layer\"},[_c('p',[_c('strong',[_vm._v(\"URL: \")]),_vm._v(_vm._s(_vm.url))])]):_vm._e()}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./IxWmsLayer.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!./IxWmsLayer.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./IxWmsLayer.vue?vue&type=template&id=41702c76&scoped=true&\"\nimport script from \"./IxWmsLayer.vue?vue&type=script&lang=js&\"\nexport * from \"./IxWmsLayer.vue?vue&type=script&lang=js&\"\nimport style0 from \"./IxWmsLayer.vue?vue&type=style&index=0&id=41702c76&lang=scss&scoped=true&\"\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 \"41702c76\",\n null\n \n)\n\nexport default component.exports","var meta = require('@turf/meta');\nvar rbush = require('geojson-rbush');\nvar helpers = require('@turf/helpers');\nvar flatten = require('@turf/flatten');\nvar truncate = require('@turf/truncate');\nvar invariant = require('@turf/invariant');\nvar lineSegment = require('@turf/line-segment');\nvar pointOnLine = require('@turf/point-on-line');\nvar lineIntersect = require('@turf/line-intersect');\nvar getCoords = invariant.getCoords;\nvar lineString = helpers.lineString;\nvar getGeomType = invariant.getGeomType;\nvar featureEach = meta.featureEach;\nvar featureReduce = meta.featureReduce;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Split a LineString by another GeoJSON Feature.\n *\n * @name lineSplit\n * @param {Feature} line LineString Feature to split\n * @param {Feature} splitter Feature used to split line\n * @returns {FeatureCollection} Split LineStrings\n * @example\n * var line = turf.lineString([[120, -25], [145, -25]]);\n * var splitter = turf.lineString([[130, -15], [130, -35]]);\n *\n * var split = turf.lineSplit(line, splitter);\n *\n * //addToMap\n * var addToMap = [line, splitter]\n */\nmodule.exports = function (line, splitter) {\n if (!line) throw new Error('line is required');\n if (!splitter) throw new Error('splitter is required');\n\n var lineType = getGeomType(line);\n var splitterType = getGeomType(splitter);\n\n if (lineType !== 'LineString') throw new Error('line must be LineString');\n if (splitterType === 'FeatureCollection') throw new Error('splitter cannot be a FeatureCollection');\n if (splitterType === 'GeometryCollection') throw new Error('splitter cannot be a GeometryCollection');\n\n // remove excessive decimals from splitter\n // to avoid possible approximation issues in rbush\n var truncatedSplitter = truncate(splitter, 7);\n\n switch (splitterType) {\n case 'Point':\n return splitLineWithPoint(line, truncatedSplitter);\n case 'MultiPoint':\n return splitLineWithPoints(line, flatten(truncatedSplitter));\n case 'LineString':\n case 'MultiLineString':\n case 'Polygon':\n case 'MultiPolygon':\n return splitLineWithPoints(line, lineIntersect(line, truncatedSplitter));\n }\n};\n\n/**\n * Split LineString with MultiPoint\n *\n * @private\n * @param {Feature} line LineString\n * @param {FeatureCollection} splitter Point\n * @returns {FeatureCollection} split LineStrings\n */\nfunction splitLineWithPoints(line, splitter) {\n var results = [];\n var tree = rbush();\n\n featureEach(splitter, function (point) {\n // Add index/id to features (needed for filter)\n results.forEach(function (feature, index) {\n feature.id = index;\n });\n // First Point - doesn't need to handle any previous line results\n if (!results.length) {\n results = splitLineWithPoint(line, point).features;\n tree.load(featureCollection(results));\n // Split with remaining points - lines might needed to be split multiple times\n } else {\n // Find all lines that are within the splitter's bbox\n var search = tree.search(point);\n\n // RBush might return multiple lines - only process the closest line to splitter\n var closestLine = findClosestFeature(point, search);\n\n // Remove closest line from results since this will be split into two lines\n // This removes any duplicates inside the results & index\n results = results.filter(function (feature) { return feature.id !== closestLine.id; });\n tree.remove(closestLine);\n\n // Append the two newly split lines into the results\n featureEach(splitLineWithPoint(closestLine, point), function (line) {\n results.push(line);\n tree.insert(line);\n });\n }\n });\n return featureCollection(results);\n}\n\n/**\n * Split LineString with Point\n *\n * @private\n * @param {Feature} line LineString\n * @param {Feature} splitter Point\n * @returns {FeatureCollection} split LineStrings\n */\nfunction splitLineWithPoint(line, splitter) {\n var results = [];\n\n // handle endpoints\n var startPoint = getCoords(line)[0];\n var endPoint = getCoords(line)[line.geometry.coordinates.length - 1];\n if (pointsEquals(startPoint, getCoords(splitter)) ||\n pointsEquals(endPoint, getCoords(splitter))) return featureCollection([line]);\n\n // Create spatial index\n var tree = rbush();\n var segments = lineSegment(line);\n tree.load(segments);\n\n // Find all segments that are within bbox of splitter\n var search = tree.search(splitter);\n\n // Return itself if point is not within spatial index\n if (!search.features.length) return featureCollection([line]);\n\n // RBush might return multiple lines - only process the closest line to splitter\n var closestSegment = findClosestFeature(splitter, search);\n\n // Initial value is the first point of the first segments (beginning of line)\n var initialValue = [startPoint];\n var lastCoords = featureReduce(segments, function (previous, current, index) {\n var currentCoords = getCoords(current)[1];\n var splitterCoords = getCoords(splitter);\n\n // Location where segment intersects with line\n if (index === closestSegment.id) {\n previous.push(splitterCoords);\n results.push(lineString(previous));\n // Don't duplicate splitter coordinate (Issue #688)\n if (pointsEquals(splitterCoords, currentCoords)) return [splitterCoords];\n return [splitterCoords, currentCoords];\n\n // Keep iterating over coords until finished or intersection is found\n } else {\n previous.push(currentCoords);\n return previous;\n }\n }, initialValue);\n // Append last line to final split results\n if (lastCoords.length > 1) {\n results.push(lineString(lastCoords));\n }\n return featureCollection(results);\n}\n\n\n/**\n * Find Closest Feature\n *\n * @private\n * @param {Feature} point Feature must be closest to this point\n * @param {FeatureCollection} lines Collection of Features\n * @returns {Feature} closest LineString\n */\nfunction findClosestFeature(point, lines) {\n if (!lines.features) throw new Error(' must contain features');\n // Filter to one segment that is the closest to the line\n if (lines.features.length === 1) return lines.features[0];\n\n var closestFeature;\n var closestDistance = Infinity;\n featureEach(lines, function (segment) {\n var pt = pointOnLine(segment, point);\n var dist = pt.properties.dist;\n if (dist < closestDistance) {\n closestFeature = segment;\n closestDistance = dist;\n }\n });\n return closestFeature;\n}\n\n/**\n * Compares two points and returns if they are equals\n *\n * @private\n * @param {Array} pt1 point\n * @param {Array} pt2 point\n * @returns {boolean} true if they are equals\n */\nfunction pointsEquals(pt1, pt2) {\n return pt1[0] === pt2[0] && pt1[1] === pt2[1];\n}\n","'use strict';\n\nvar inside = require('@turf/inside'),\n _require = require('@turf/helpers'),\n point = _require.point;\n\n/** Returns the direction of the point q relative to the vector p1 -> p2.\n * Implementation of geos::algorithm::CGAlgorithm::orientationIndex()\n * (same as geos::algorithm::CGAlgorithm::computeOrientation())\n *\n * @param {Number[]} p1 - the origin point of the vector\n * @param {Number[]} p2 - the final point of the vector\n * @param {Number[]} q - the point to compute the direction to\n *\n * @returns {Number} - 1 if q is ccw (left) from p1->p2,\n * -1 if q is cw (right) from p1->p2,\n * 0 if q is colinear with p1->p2\n */\nfunction orientationIndex(p1, p2, q) {\n var dx1 = p2[0] - p1[0],\n dy1 = p2[1] - p1[1],\n dx2 = q[0] - p2[0],\n dy2 = q[1] - p2[1];\n\n return Math.sign(dx1 * dy2 - dx2 * dy1);\n}\n\n/** Checks if two envelopes are equal.\n * The function assumes that the arguments are envelopes, i.e.: Rectangular polygon\n *\n * @param {Feature} env1 - Envelope\n * @param {Feature} env2 - Envelope\n * @returns {Boolean} - True if the envelopes are equal\n */\nfunction envelopeIsEqual(env1, env2) {\n var envX1 = env1.geometry.coordinates.map(function (c) {\n return c[0];\n }),\n envY1 = env1.geometry.coordinates.map(function (c) {\n return c[1];\n }),\n envX2 = env2.geometry.coordinates.map(function (c) {\n return c[0];\n }),\n envY2 = env2.geometry.coordinates.map(function (c) {\n return c[1];\n });\n\n return Math.max(null, envX1) === Math.max(null, envX2) && Math.max(null, envY1) === Math.max(null, envY2) && Math.min(null, envX1) === Math.min(null, envX2) && Math.min(null, envY1) === Math.min(null, envY2);\n}\n\n/** Check if a envelope is contained in other one.\n * The function assumes that the arguments are envelopes, i.e.: Convex polygon\n * XXX: Envelopes are rectangular, checking if a point is inside a rectangule is something easy,\n * this could be further improved.\n *\n * @param {Feature} self - Envelope\n * @param {Feature} env - Envelope\n * @returns {Boolean} - True if env is contained in self\n */\nfunction envelopeContains(self, env) {\n return env.geometry.coordinates[0].every(function (c) {\n return inside(point(c), self);\n });\n}\n\n/** Checks if two coordinates are equal.\n *\n * @param {Number[]} coord1 - First coordinate\n * @param {Number[]} coord2 - Second coordinate\n * @returns {Boolean} - True if coordinates are equal\n */\nfunction coordinatesEqual(coord1, coord2) {\n return coord1[0] === coord2[0] && coord1[1] === coord2[1];\n}\n\nmodule.exports = {\n orientationIndex: orientationIndex,\n envelopeIsEqual: envelopeIsEqual,\n envelopeContains: envelopeContains,\n coordinatesEqual: coordinatesEqual\n};","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('LabelAndMessage',{attrs:{\"id\":_vm.id,\"label\":_vm.label,\"required\":_vm.required,\"placement\":_vm.placement,\"feedback-classes\":_vm.feedbackClasses,\"description\":_vm.combinedDescription,\"message\":_vm.message}},[_c('div',{staticClass:\"input-field\",class:{'input-group': _vm.addon || _vm.unit || _vm.usePercent || _vm.$slots.inputGroup}},[_c('div',{staticClass:\"input-wrapper\",attrs:{\"title\":_vm.title}},[_c('input',{ref:\"input\",staticClass:\"form-control\",class:{faded: _vm.faded, 'has-input': _vm.inputText, centered: _vm.centered},attrs:{\"id\":_vm.id,\"name\":_vm.name,\"readonly\":_vm.readonly || _vm.disabled,\"disabled\":_vm.readonly || _vm.disabled,\"type\":\"text\",\"aria-describedby\":(_vm.id + \"-sr-status\"),\"placeholder\":_vm.placeholder},domProps:{\"value\":_vm.displayValue},on:{\"input\":function($event){return _vm.onInput($event.target.value)},\"blur\":_vm.updateText}}),(_vm.clearButton)?_c('InputClearButton',{attrs:{\"show\":!!_vm.value,\"right\":\"6px\"},on:{\"click\":_vm.clear}}):_c('div',{staticClass:\"icon\"},[_vm._t(\"icon\")],2)],1),(_vm.state)?_c('span',{staticClass:\"sr-only\",attrs:{\"id\":(_vm.id + \"-status-sr\")}},[_vm._v(_vm._s(_vm.srState))]):_vm._e(),(_vm.addon || _vm.unit || _vm.usePercent)?_c('span',{staticClass:\"input-group-addon\"},[(_vm.usePercent)?_c('span',[_vm._v(_vm._s(_vm.$i18n.translateUnit('%')))]):_vm._e(),(_vm.unit && _vm.unit !== '%')?_c('span',[_vm._v(_vm._s(_vm.$i18n.translateUnit(_vm.unit)))]):_vm._e(),_vm._v(\" \"+_vm._s(_vm.addon)+\"\\n \")]):_vm._e(),_vm._t(\"inputGroup\")],2),_vm._t(\"label\",null,{\"slot\":\"label\"}),(_vm.$slots.description)?_vm._t(\"description\",null,{\"slot\":\"description\"}):_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./NumericInput.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!./NumericInput.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./NumericInput.vue?vue&type=template&id=505bcb48&scoped=true&lang=html&\"\nimport script from \"./NumericInput.vue?vue&type=script&lang=js&\"\nexport * from \"./NumericInput.vue?vue&type=script&lang=js&\"\nimport style0 from \"./NumericInput.vue?vue&type=style&index=0&id=505bcb48&lang=scss&scoped=true&\"\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 \"505bcb48\",\n null\n \n)\n\nexport default component.exports","\"use strict\"; \"use restrict\";\n\nmodule.exports = UnionFind;\n\nfunction UnionFind(count) {\n this.roots = new Array(count);\n this.ranks = new Array(count);\n \n for(var i=0; i} points representing the exploded input features\n * @throws {Error} if it encounters an unknown geometry type\n * @example\n * var poly = {\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Polygon\",\n * \"coordinates\": [[\n * [177.434692, -17.77517],\n * [177.402076, -17.779093],\n * [177.38079, -17.803937],\n * [177.40242, -17.826164],\n * [177.438468, -17.824857],\n * [177.454948, -17.796746],\n * [177.434692, -17.77517]\n * ]]\n * }\n * };\n *\n * var points = turf.explode(poly);\n *\n * //=poly\n *\n * //=points\n */\nmodule.exports = function (geojson) {\n var points = [];\n if (geojson.type === 'FeatureCollection') {\n featureEach(geojson, function (feature) {\n coordEach(feature, function (coord) {\n points.push(point(coord, feature.properties));\n });\n });\n } else {\n coordEach(geojson, function (coord) {\n points.push(point(coord, geojson.properties));\n });\n }\n return featureCollection(points);\n};\n","export default function(x) {\n return x;\n}\n","import identity from \"./identity\";\n\nexport default function(transform) {\n if (transform == null) return identity;\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(input, i) {\n if (!i) x0 = y0 = 0;\n var j = 2, n = input.length, output = new Array(n);\n output[0] = (x0 += input[0]) * kx + dx;\n output[1] = (y0 += input[1]) * ky + dy;\n while (j < n) output[j] = input[j], ++j;\n return output;\n };\n}\n","import transform from \"./transform\";\n\nexport default function(topology) {\n var t = transform(topology.transform), key,\n x0 = Infinity, y0 = x0, x1 = -x0, y1 = -x0;\n\n function bboxPoint(p) {\n p = t(p);\n if (p[0] < x0) x0 = p[0];\n if (p[0] > x1) x1 = p[0];\n if (p[1] < y0) y0 = p[1];\n if (p[1] > y1) y1 = p[1];\n }\n\n function bboxGeometry(o) {\n switch (o.type) {\n case \"GeometryCollection\": o.geometries.forEach(bboxGeometry); break;\n case \"Point\": bboxPoint(o.coordinates); break;\n case \"MultiPoint\": o.coordinates.forEach(bboxPoint); break;\n }\n }\n\n topology.arcs.forEach(function(arc) {\n var i = -1, n = arc.length, p;\n while (++i < n) {\n p = t(arc[i], i);\n if (p[0] < x0) x0 = p[0];\n if (p[0] > x1) x1 = p[0];\n if (p[1] < y0) y0 = p[1];\n if (p[1] > y1) y1 = p[1];\n }\n });\n\n for (key in topology.objects) {\n bboxGeometry(topology.objects[key]);\n }\n\n return [x0, y0, x1, y1];\n}\n","export default function(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","import reverse from \"./reverse\";\nimport transform from \"./transform\";\n\nexport default function(topology, o) {\n return o.type === \"GeometryCollection\"\n ? {type: \"FeatureCollection\", features: o.geometries.map(function(o) { return feature(topology, o); })}\n : feature(topology, o);\n}\n\nexport function feature(topology, o) {\n var id = o.id,\n bbox = o.bbox,\n properties = o.properties == null ? {} : o.properties,\n geometry = object(topology, o);\n return id == null && bbox == null ? {type: \"Feature\", properties: properties, geometry: geometry}\n : bbox == null ? {type: \"Feature\", id: id, properties: properties, geometry: geometry}\n : {type: \"Feature\", id: id, bbox: bbox, properties: properties, geometry: geometry};\n}\n\nexport function object(topology, o) {\n var transformPoint = transform(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; k < n; ++k) {\n points.push(transformPoint(a[k], k));\n }\n if (i < 0) reverse(points, n);\n }\n\n function point(p) {\n return transformPoint(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]); // This should never happen per the specification.\n return points;\n }\n\n function ring(arcs) {\n var points = line(arcs);\n while (points.length < 4) points.push(points[0]); // This may happen if an arc has only two points.\n return points;\n }\n\n function polygon(arcs) {\n return arcs.map(ring);\n }\n\n function geometry(o) {\n var type = o.type, coordinates;\n switch (type) {\n case \"GeometryCollection\": return {type: type, geometries: o.geometries.map(geometry)};\n case \"Point\": coordinates = point(o.coordinates); break;\n case \"MultiPoint\": coordinates = o.coordinates.map(point); break;\n case \"LineString\": coordinates = line(o.arcs); break;\n case \"MultiLineString\": coordinates = o.arcs.map(line); break;\n case \"Polygon\": coordinates = polygon(o.arcs); break;\n case \"MultiPolygon\": coordinates = o.arcs.map(polygon); break;\n default: return null;\n }\n return {type: type, coordinates: coordinates};\n }\n\n return geometry(o);\n}\n","export default function(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","import {object} from \"./feature\";\nimport stitch from \"./stitch\";\n\nexport default function(topology) {\n return object(topology, meshArcs.apply(this, arguments));\n}\n\nexport function meshArcs(topology, object, filter) {\n var arcs, i, n;\n if (arguments.length > 1) arcs = extractArcs(topology, object, filter);\n else for (i = 0, arcs = new Array(n = topology.arcs.length); i < n; ++i) arcs[i] = i;\n return {type: \"MultiLineString\", arcs: stitch(topology, arcs)};\n}\n\nfunction extractArcs(topology, object, filter) {\n var arcs = [],\n geomsByArc = [],\n geom;\n\n function extract0(i) {\n var j = i < 0 ? ~i : i;\n (geomsByArc[j] || (geomsByArc[j] = [])).push({i: i, g: geom});\n }\n\n function extract1(arcs) {\n arcs.forEach(extract0);\n }\n\n function extract2(arcs) {\n arcs.forEach(extract1);\n }\n\n function extract3(arcs) {\n arcs.forEach(extract2);\n }\n\n function geometry(o) {\n switch (geom = o, o.type) {\n case \"GeometryCollection\": o.geometries.forEach(geometry); break;\n case \"LineString\": extract1(o.arcs); break;\n case \"MultiLineString\": case \"Polygon\": extract2(o.arcs); break;\n case \"MultiPolygon\": extract3(o.arcs); break;\n }\n }\n\n geometry(object);\n\n geomsByArc.forEach(filter == null\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\n return arcs;\n}\n","import {object} from \"./feature\";\nimport stitch from \"./stitch\";\n\nfunction planarRingArea(ring) {\n var i = -1, n = ring.length, a, b = ring[n - 1], area = 0;\n while (++i < n) a = b, b = ring[i], area += a[0] * b[1] - a[1] * b[0];\n return Math.abs(area); // Note: doubled area!\n}\n\nexport default function(topology) {\n return object(topology, mergeArcs.apply(this, arguments));\n}\n\nexport function mergeArcs(topology, objects) {\n var polygonsByArc = {},\n polygons = [],\n groups = [];\n\n objects.forEach(geometry);\n\n function geometry(o) {\n switch (o.type) {\n case \"GeometryCollection\": o.geometries.forEach(geometry); break;\n case \"Polygon\": extract(o.arcs); break;\n case \"MultiPolygon\": o.arcs.forEach(extract); break;\n }\n }\n\n function extract(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 planarRingArea(object(topology, {type: \"Polygon\", arcs: [ring]}).coordinates[0]);\n }\n\n polygons.forEach(function(polygon) {\n if (!polygon._) {\n var group = [],\n neighbors = [polygon];\n polygon._ = 1;\n groups.push(group);\n while (polygon = neighbors.pop()) {\n group.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: groups.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 = stitch(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","export default function(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","import bisect from \"./bisect\";\n\nexport default function(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","import identity from \"./identity\";\n\nexport default function(transform) {\n if (transform == null) return identity;\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(input, i) {\n if (!i) x0 = y0 = 0;\n var j = 2,\n n = input.length,\n output = new Array(n),\n x1 = Math.round((input[0] - dx) / kx),\n y1 = Math.round((input[1] - dy) / ky);\n output[0] = x1 - x0, x0 = x1;\n output[1] = y1 - y0, y0 = y1;\n while (j < n) output[j] = input[j], ++j;\n return output;\n };\n}\n","import bbox from \"./bbox\";\nimport untransform from \"./untransform\";\n\nexport default function(topology, transform) {\n if (topology.transform) throw new Error(\"already quantized\");\n\n if (!transform || !transform.scale) {\n if (!((n = Math.floor(transform)) >= 2)) throw new Error(\"n must be ≥2\");\n box = topology.bbox || bbox(topology);\n var x0 = box[0], y0 = box[1], x1 = box[2], y1 = box[3], n;\n transform = {scale: [x1 - x0 ? (x1 - x0) / (n - 1) : 1, y1 - y0 ? (y1 - y0) / (n - 1) : 1], translate: [x0, y0]};\n } else {\n box = topology.bbox;\n }\n\n var t = untransform(transform), box, key, inputs = topology.objects, outputs = {};\n\n function quantizePoint(point) {\n return t(point);\n }\n\n function quantizeGeometry(input) {\n var output;\n switch (input.type) {\n case \"GeometryCollection\": output = {type: \"GeometryCollection\", geometries: input.geometries.map(quantizeGeometry)}; break;\n case \"Point\": output = {type: \"Point\", coordinates: quantizePoint(input.coordinates)}; break;\n case \"MultiPoint\": output = {type: \"MultiPoint\", coordinates: input.coordinates.map(quantizePoint)}; break;\n default: return input;\n }\n if (input.id != null) output.id = input.id;\n if (input.bbox != null) output.bbox = input.bbox;\n if (input.properties != null) output.properties = input.properties;\n return output;\n }\n\n function quantizeArc(input) {\n var i = 0, j = 1, n = input.length, p, output = new Array(n); // pessimistic\n output[0] = t(input[0], 0);\n while (++i < n) if ((p = t(input[i], i))[0] || p[1]) output[j++] = p; // non-coincident points\n if (j === 1) output[j++] = [0, 0]; // an arc must have at least two points\n output.length = j;\n return output;\n }\n\n for (key in inputs) outputs[key] = quantizeGeometry(inputs[key]);\n\n return {\n type: \"Topology\",\n bbox: box,\n transform: transform,\n objects: outputs,\n arcs: topology.arcs.map(quantizeArc)\n };\n}\n","export {default as bbox} from \"./src/bbox\";\nexport {default as feature} from \"./src/feature\";\nexport {default as mesh, meshArcs} from \"./src/mesh\";\nexport {default as merge, mergeArcs} from \"./src/merge\";\nexport {default as neighbors} from \"./src/neighbors\";\nexport {default as quantize} from \"./src/quantize\";\nexport {default as transform} from \"./src/transform\";\nexport {default as untransform} from \"./src/untransform\";\n","var arc = require('./arc');\nvar getCoord = require('@turf/invariant').getCoord;\n\n/**\n * Calculate great circles routes as {@link LineString}\n *\n * @name greatCircle\n * @param {Geometry|Feature|Array} start source point feature\n * @param {Geometry|Feature|Array} end destination point feature\n * @param {Object} [properties={}] line feature properties\n * @param {number} [npoints=100] number of points\n * @param {number} [offset=10] offset controls the likelyhood that lines will\n * be split which cross the dateline. The higher the number the more likely.\n * @returns {Feature} great circle line feature\n * @example\n * var start = turf.point([-122, 48]);\n * var end = turf.point([-77, 39]);\n *\n * var greatCircle = turf.greatCircle(start, end, {'name': 'Seattle to DC'});\n *\n * //addToMap\n * var addToMap = [start, end, greatCircle]\n */\nmodule.exports = function (start, end, properties, npoints, offset) {\n start = getCoord(start);\n end = getCoord(end);\n properties = properties || {};\n npoints = npoints || 100;\n offset = offset || 10;\n\n var generator = new arc.GreatCircle({x: start[0], y: start[1]}, {x: end[0], y: end[1]}, properties);\n /* eslint-disable */\n var line = generator.Arc(npoints, {offset: offset});\n /* eslint-enable */\n\n return line.json();\n};\n","\"use strict\"\n\nmodule.exports = robustSubtract\n\n//Easy case: Add two scalars\nfunction scalarScalar(a, b) {\n var x = a + b\n var bv = x - a\n var av = x - bv\n var br = b - bv\n var ar = a - av\n var y = ar + br\n if(y) {\n return [y, x]\n }\n return [x]\n}\n\nfunction robustSubtract(e, f) {\n var ne = e.length|0\n var nf = f.length|0\n if(ne === 1 && nf === 1) {\n return scalarScalar(e[0], -f[0])\n }\n var n = ne + nf\n var g = new Array(n)\n var count = 0\n var eptr = 0\n var fptr = 0\n var abs = Math.abs\n var ei = e[eptr]\n var ea = abs(ei)\n var fi = -f[fptr]\n var fa = abs(fi)\n var a, b\n if(ea < fa) {\n b = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n b = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n if((eptr < ne && ea < fa) || (fptr >= nf)) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n var x = a + b\n var bv = x - a\n var y = b - bv\n var q0 = y\n var q1 = x\n var _x, _bv, _av, _br, _ar\n while(eptr < ne && fptr < nf) {\n if(ea < fa) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n }\n while(eptr < ne) {\n a = ei\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n }\n }\n while(fptr < nf) {\n a = fi\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n } \n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n }\n }\n if(q0) {\n g[count++] = q0\n }\n if(q1) {\n g[count++] = q1\n }\n if(!count) {\n g[count++] = 0.0 \n }\n g.length = count\n return g\n}","var coordEach = require('@turf/meta').coordEach;\n\n/**\n * Takes a set of features, calculates the bbox of all input features, and returns a bounding box.\n *\n * @name bbox\n * @param {FeatureCollection|Feature} geojson input features\n * @returns {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @example\n * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]]);\n * var bbox = turf.bbox(line);\n * var bboxPolygon = turf.bboxPolygon(bbox);\n *\n * //addToMap\n * var addToMap = [line, bboxPolygon]\n */\nmodule.exports = function (geojson) {\n var bbox = [Infinity, Infinity, -Infinity, -Infinity];\n coordEach(geojson, function (coord) {\n if (bbox[0] > coord[0]) bbox[0] = coord[0];\n if (bbox[1] > coord[1]) bbox[1] = coord[1];\n if (bbox[2] < coord[0]) bbox[2] = coord[0];\n if (bbox[3] < coord[1]) bbox[3] = coord[1];\n });\n return bbox;\n};\n","var GeojsonEquality = require('geojson-equality');\nvar cleanCoords = require('@turf/clean-coords');\nvar invariant = require('@turf/invariant');\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Determine whether two geometries of the same type have identical X,Y coordinate values.\n * See http://edndoc.esri.com/arcsde/9.0/general_topics/understand_spatial_relations.htm\n *\n * @name booleanEqual\n * @param {Geometry|Feature} feature1 GeoJSON input\n * @param {Geometry|Feature} feature2 GeoJSON input\n * @returns {boolean} true if the objects are equal, false otherwise\n * @example\n * var pt1 = turf.point([0, 0]);\n * var pt2 = turf.point([0, 0]);\n * var pt3 = turf.point([1, 1]);\n *\n * turf.booleanEqual(pt1, pt2);\n * //= true\n * turf.booleanEqual(pt2, pt3);\n * //= false\n */\nmodule.exports = function (feature1, feature2) {\n // validation\n if (!feature1) throw new Error('feature1 is required');\n if (!feature2) throw new Error('feature2 is required');\n var type1 = getGeomType(feature1);\n var type2 = getGeomType(feature2);\n if (type1 !== type2) return false;\n\n var equality = new GeojsonEquality({precision: 6});\n return equality.compare(cleanCoords(feature1), cleanCoords(feature2));\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"search\"},[_c('LabelAndMessage',{scopedSlots:_vm._u([(_vm.$slots.label)?{key:\"label\",fn:function(){return [_vm._t(\"label\")]},proxy:true}:null],null,true)},[_c('SearchBar',{attrs:{\"value\":_vm.value,\"debounced\":\"\"},on:{\"input\":function($event){return _vm.$emit('input', $event)}}})],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./Search.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!./Search.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./Search.vue?vue&type=template&id=2278b0d6&scoped=true&lang=html&\"\nimport script from \"./Search.vue?vue&type=script&lang=js&\"\nexport * from \"./Search.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 \"2278b0d6\",\n null\n \n)\n\nexport default component.exports","var meta = require('@turf/meta');\nvar helpers = require('@turf/helpers');\nvar bearing = require('@turf/bearing');\nvar distance = require('@turf/distance');\nvar invariant = require('@turf/invariant');\nvar destination = require('@turf/destination');\nvar lineIntersects = require('@turf/line-intersect');\nvar point = helpers.point;\nvar getCoords = invariant.getCoords;\nvar lineString = helpers.lineString;\nvar flattenEach = meta.flattenEach;\n\n/**\n * Takes a {@link Point} and a {@link LineString} and calculates the closest Point on the (Multi)LineString.\n *\n * @name pointOnLine\n * @param {Geometry|Feature} lines lines to snap to\n * @param {Geometry|Feature|number[]} pt point to snap from\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers\n * @returns {Feature} closest point on the `line` to `point`. The properties object will contain three values: `index`: closest point was found on nth line part, `dist`: distance between pt and the closest point, `location`: distance along the line between start and the closest point.\n * @example\n * var line = turf.lineString([\n * [-77.031669, 38.878605],\n * [-77.029609, 38.881946],\n * [-77.020339, 38.884084],\n * [-77.025661, 38.885821],\n * [-77.021884, 38.889563],\n * [-77.019824, 38.892368]\n * ]);\n * var pt = turf.point([-77.037076, 38.884017]);\n *\n * var snapped = turf.pointOnLine(line, pt, 'miles');\n *\n * //addToMap\n * var addToMap = [line, pt, snapped];\n * snapped.properties['marker-color'] = '#00f';\n */\nmodule.exports = function (lines, pt, units) {\n // validation\n var type = (lines.geometry) ? lines.geometry.type : lines.type;\n if (type !== 'LineString' && type !== 'MultiLineString') {\n throw new Error('lines must be LineString or MultiLineString');\n }\n\n var closestPt = point([Infinity, Infinity], {\n dist: Infinity\n });\n\n var length = 0.0;\n flattenEach(lines, function (line) {\n var coords = getCoords(line);\n\n for (var i = 0; i < coords.length - 1; i++) {\n //start\n var start = point(coords[i]);\n start.properties.dist = distance(pt, start, units);\n //stop\n var stop = point(coords[i + 1]);\n stop.properties.dist = distance(pt, stop, units);\n // sectionLength\n var sectionLength = distance(start, stop, units);\n //perpendicular\n var heightDistance = Math.max(start.properties.dist, stop.properties.dist);\n var direction = bearing(start, stop);\n var perpendicularPt1 = destination(pt, heightDistance, direction + 90, units);\n var perpendicularPt2 = destination(pt, heightDistance, direction - 90, units);\n var intersect = lineIntersects(lineString([perpendicularPt1.geometry.coordinates, perpendicularPt2.geometry.coordinates]), lineString([start.geometry.coordinates, stop.geometry.coordinates]));\n var intersectPt = null;\n if (intersect.features.length > 0) {\n intersectPt = intersect.features[0];\n intersectPt.properties.dist = distance(pt, intersectPt, units);\n intersectPt.properties.location = length + distance(start, intersectPt, units);\n }\n\n if (start.properties.dist < closestPt.properties.dist) {\n closestPt = start;\n closestPt.properties.index = i;\n closestPt.properties.location = length;\n }\n if (stop.properties.dist < closestPt.properties.dist) {\n closestPt = stop;\n closestPt.properties.index = i + 1;\n closestPt.properties.location = length + sectionLength;\n }\n if (intersectPt && intersectPt.properties.dist < closestPt.properties.dist) {\n closestPt = intersectPt;\n closestPt.properties.index = i;\n }\n // update length\n length += sectionLength;\n }\n\n });\n\n return closestPt;\n};\n","var each = require('@turf/meta').coordEach;\n\n/**\n * Takes a set of features, calculates the bbox of all input features, and returns a bounding box.\n *\n * @name bbox\n * @param {(Feature|FeatureCollection)} geojson input features\n * @returns {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @addToMap features, bboxPolygon\n * @example\n * var pt1 = turf.point([114.175329, 22.2524])\n * var pt2 = turf.point([114.170007, 22.267969])\n * var pt3 = turf.point([114.200649, 22.274641])\n * var pt4 = turf.point([114.200649, 22.274641])\n * var pt5 = turf.point([114.186744, 22.265745])\n * var features = turf.featureCollection([pt1, pt2, pt3, pt4, pt5])\n *\n * var bbox = turf.bbox(features);\n *\n * var bboxPolygon = turf.bboxPolygon(bbox);\n *\n * //=bbox\n *\n * //=bboxPolygon\n */\nmodule.exports = function (geojson) {\n var bbox = [Infinity, Infinity, -Infinity, -Infinity];\n each(geojson, function (coord) {\n if (bbox[0] > coord[0]) bbox[0] = coord[0];\n if (bbox[1] > coord[1]) bbox[1] = coord[1];\n if (bbox[2] < coord[0]) bbox[2] = coord[0];\n if (bbox[3] < coord[1]) bbox[3] = coord[1];\n });\n return bbox;\n};\n","var inside = require('@turf/inside');\nvar calcBbox = require('@turf/bbox');\nvar invariant = require('@turf/invariant');\nvar isPointOnLine = require('@turf/boolean-point-on-line');\nvar getGeom = invariant.getGeom;\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Boolean-within returns true if the first geometry is completely within the second geometry.\n * The interiors of both geometries must intersect and, the interior and boundary of the primary (geometry a)\n * must not intersect the exterior of the secondary (geometry b).\n * Boolean-within returns the exact opposite result of the `@turf/boolean-contains`.\n *\n * @name booleanWithin\n * @param {Geometry|Feature} feature1 GeoJSON Feature or Geometry\n * @param {Geometry|Feature} feature2 GeoJSON Feature or Geometry\n * @returns {boolean} true/false\n * @example\n * const line = turf.lineString([[1, 1], [1, 2], [1, 3], [1, 4]]);\n * const point = turf.point([1, 2]);\n *\n * turf.booleanWithin(point, line);\n * //=true\n */\nmodule.exports = function (feature1, feature2) {\n var type1 = getGeomType(feature1);\n var type2 = getGeomType(feature2);\n var geom1 = getGeom(feature1);\n var geom2 = getGeom(feature2);\n\n switch (type1) {\n case 'Point':\n switch (type2) {\n case 'MultiPoint':\n return isPointInMultiPoint(geom1, geom2);\n case 'LineString':\n return isPointOnLine(geom1, geom2, true);\n case 'Polygon':\n return inside(geom1, geom2, true);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'MultiPoint':\n switch (type2) {\n case 'MultiPoint':\n return isMultiPointInMultiPoint(geom1, geom2);\n case 'LineString':\n return isMultiPointOnLine(geom1, geom2);\n case 'Polygon':\n return isMultiPointInPoly(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'LineString':\n switch (type2) {\n case 'LineString':\n return isLineOnLine(geom1, geom2);\n case 'Polygon':\n return isLineInPoly(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'Polygon':\n switch (type2) {\n case 'Polygon':\n return isPolyInPoly(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n default:\n throw new Error('feature1 ' + type1 + ' geometry not supported');\n }\n};\n\nfunction isPointInMultiPoint(point, multiPoint) {\n var i;\n var output = false;\n for (i = 0; i < multiPoint.coordinates.length; i++) {\n if (compareCoords(multiPoint.coordinates[i], point.coordinates)) {\n output = true;\n break;\n }\n }\n return output;\n}\n\nfunction isMultiPointInMultiPoint(multiPoint1, multiPoint2) {\n for (var i = 0; i < multiPoint1.coordinates.length; i++) {\n var anyMatch = false;\n for (var i2 = 0; i2 < multiPoint2.coordinates.length; i2++) {\n if (compareCoords(multiPoint1.coordinates[i], multiPoint2.coordinates[i2])) {\n anyMatch = true;\n }\n }\n if (!anyMatch) {\n return false;\n }\n }\n return true;\n}\n\nfunction isMultiPointOnLine(multiPoint, lineString) {\n var foundInsidePoint = false;\n\n for (var i = 0; i < multiPoint.coordinates.length; i++) {\n if (!isPointOnLine(multiPoint.coordinates[i], lineString)) {\n return false;\n }\n if (!foundInsidePoint) {\n foundInsidePoint = isPointOnLine(multiPoint.coordinates[i], lineString, true);\n }\n }\n return foundInsidePoint;\n}\n\nfunction isMultiPointInPoly(multiPoint, polygon) {\n var output = true;\n var oneInside = false;\n for (var i = 0; i < multiPoint.coordinates.length; i++) {\n var isInside = inside(multiPoint.coordinates[1], polygon);\n if (!isInside) {\n output = false;\n break;\n }\n if (!oneInside) {\n isInside = inside(multiPoint.coordinates[1], polygon, true);\n }\n }\n return output && isInside;\n}\n\nfunction isLineOnLine(lineString1, lineString2) {\n for (var i = 0; i < lineString1.coordinates.length; i++) {\n if (!isPointOnLine(lineString1.coordinates[i], lineString2)) {\n return false;\n }\n }\n return true;\n}\n\nfunction isLineInPoly(linestring, polygon) {\n var polyBbox = calcBbox(polygon);\n var lineBbox = calcBbox(linestring);\n if (!doBBoxOverlap(polyBbox, lineBbox)) {\n return false;\n }\n var foundInsidePoint = false;\n\n for (var i = 0; i < linestring.coordinates.length - 1; i++) {\n if (!inside(linestring.coordinates[i], polygon)) {\n return false;\n }\n if (!foundInsidePoint) {\n foundInsidePoint = inside(linestring.coordinates[i], polygon, true);\n }\n if (!foundInsidePoint) {\n var midpoint = getMidpoint(linestring.coordinates[i], linestring.coordinates[i + 1]);\n foundInsidePoint = inside(midpoint, polygon, true);\n\n }\n }\n return foundInsidePoint;\n}\n\n/**\n * Is Polygon2 in Polygon1\n * Only takes into account outer rings\n *\n * @private\n * @param {Geometry|Feature} feature1 Polygon1\n * @param {Geometry|Feature} feature2 Polygon2\n * @returns {boolean} true/false\n */\nfunction isPolyInPoly(feature1, feature2) {\n var poly1Bbox = calcBbox(feature1);\n var poly2Bbox = calcBbox(feature2);\n if (!doBBoxOverlap(poly2Bbox, poly1Bbox)) {\n return false;\n }\n for (var i = 0; i < feature1.coordinates[0].length; i++) {\n if (!inside(feature1.coordinates[0][i], feature2)) {\n return false;\n }\n }\n return true;\n}\n\nfunction doBBoxOverlap(bbox1, bbox2) {\n if (bbox1[0] > bbox2[0]) return false;\n if (bbox1[2] < bbox2[2]) return false;\n if (bbox1[1] > bbox2[1]) return false;\n if (bbox1[3] < bbox2[3]) return false;\n return true;\n}\n\n/**\n * compareCoords\n *\n * @private\n * @param {[number, number]} pair1 point [x,y]\n * @param {[number, number]} pair2 point [x,y]\n * @returns {boolean} true/false if coord pairs match\n */\nfunction compareCoords(pair1, pair2) {\n return pair1[0] === pair2[0] && pair1[1] === pair2[1];\n}\n\n/**\n * getMidpoint\n *\n * @private\n * @param {[number, number]} pair1 point [x,y]\n * @param {[number, number]} pair2 point [x,y]\n * @returns {[number, number]} midpoint of pair1 and pair2\n */\nfunction getMidpoint(pair1, pair2) {\n return [(pair1[0] + pair2[0]) / 2, (pair1[1] + pair2[1]) / 2];\n}\n","var distance = require('@turf/distance');\nvar helpers = require('@turf/helpers');\nvar point = helpers.point;\nvar polygon = helpers.polygon;\nvar featureCollection = helpers.featureCollection;\n\n// Precompute cosines and sines of angles used in hexagon creation\n// for performance gain\nvar cosines = [];\nvar sines = [];\nfor (var i = 0; i < 6; i++) {\n var angle = 2 * Math.PI / 6 * i;\n cosines.push(Math.cos(angle));\n sines.push(Math.sin(angle));\n}\n\n/**\n * Takes a bounding box and the diameter of the cell and returns a {@link FeatureCollection} of flat-topped\n * hexagons or triangles ({@link Polygon} features) aligned in an \"odd-q\" vertical grid as\n * described in [Hexagonal Grids](http://www.redblobgames.com/grids/hexagons/).\n *\n * @name hexGrid\n * @param {Array} bbox extent in [minX, minY, maxX, maxY] order\n * @param {number} cellDiameter diameter of the circumcircle of the hexagons, in specified units\n * @param {string} [units=kilometers] used in calculating cell size, can be degrees, radians, miles, or kilometers\n * @param {boolean} [triangles=false] whether to return as triangles instead of hexagons\n * @returns {FeatureCollection} a hexagonal grid\n * @example\n * var bbox = [-96,31,-84,40];\n * var cellDiameter = 50;\n * var units = 'miles';\n *\n * var hexgrid = turf.hexGrid(bbox, cellDiameter, units);\n *\n * //addToMap\n * var addToMap = [hexgrid];\n */\nmodule.exports = function hexGrid(bbox, cellDiameter, units, triangles) {\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n var centerY = (south + north) / 2;\n var centerX = (west + east) / 2;\n\n // https://github.com/Turfjs/turf/issues/758\n var xFraction = cellDiameter / (distance(point([west, centerY]), point([east, centerY]), units));\n var cellWidth = xFraction * (east - west);\n var yFraction = cellDiameter / (distance(point([centerX, south]), point([centerX, north]), units));\n var cellHeight = yFraction * (north - south);\n var radius = cellWidth / 2;\n\n var hex_width = radius * 2;\n var hex_height = Math.sqrt(3) / 2 * cellHeight;\n\n var box_width = east - west;\n var box_height = north - south;\n\n var x_interval = 3 / 4 * hex_width;\n var y_interval = hex_height;\n\n var x_span = box_width / (hex_width - radius / 2);\n var x_count = Math.ceil(x_span);\n if (Math.round(x_span) === x_count) {\n x_count++;\n }\n\n var x_adjust = ((x_count * x_interval - radius / 2) - box_width) / 2 - radius / 2;\n\n var y_count = Math.ceil(box_height / hex_height);\n\n var y_adjust = (box_height - y_count * hex_height) / 2;\n\n var hasOffsetY = y_count * hex_height - box_height > hex_height / 2;\n if (hasOffsetY) {\n y_adjust -= hex_height / 4;\n }\n\n var fc = featureCollection([]);\n for (var x = 0; x < x_count; x++) {\n for (var y = 0; y <= y_count; y++) {\n\n var isOdd = x % 2 === 1;\n if (y === 0 && isOdd) {\n continue;\n }\n\n if (y === 0 && hasOffsetY) {\n continue;\n }\n\n var center_x = x * x_interval + west - x_adjust;\n var center_y = y * y_interval + south + y_adjust;\n\n if (isOdd) {\n center_y -= hex_height / 2;\n }\n if (triangles) {\n fc.features.push.apply(fc.features, hexTriangles([center_x, center_y], cellWidth / 2, cellHeight / 2));\n } else {\n fc.features.push(hexagon([center_x, center_y], cellWidth / 2, cellHeight / 2));\n }\n }\n }\n\n return fc;\n};\n\n//Center should be [x, y]\nfunction hexagon(center, rx, ry) {\n var vertices = [];\n for (var i = 0; i < 6; i++) {\n var x = center[0] + rx * cosines[i];\n var y = center[1] + ry * sines[i];\n vertices.push([x, y]);\n }\n //first and last vertex must be the same\n vertices.push(vertices[0].slice());\n return polygon([vertices]);\n}\n\n//Center should be [x, y]\nfunction hexTriangles(center, rx, ry) {\n var triangles = [];\n for (var i = 0; i < 6; i++) {\n var vertices = [];\n vertices.push(center);\n vertices.push([\n center[0] + rx * cosines[i],\n center[1] + ry * sines[i]\n ]);\n vertices.push([\n center[0] + rx * cosines[(i + 1) % 6],\n center[1] + ry * sines[(i + 1) % 6]\n ]);\n vertices.push(center);\n triangles.push(polygon([vertices]));\n }\n return triangles;\n}\n","var meta = require('@turf/meta');\nvar invariant = require('@turf/invariant');\nvar rhumbDestination = require('@turf/rhumb-destination');\nvar coordEach = meta.coordEach;\nvar getCoords = invariant.getCoords;\n\n/**\n * Moves any geojson Feature or Geometry of a specified distance along a Rhumb Line\n * on the provided direction angle.\n *\n * @name transformTranslate\n * @param {GeoJSON} geojson object to be translated\n * @param {number} distance length of the motion; negative values determine motion in opposite direction\n * @param {number} direction of the motion; angle from North in decimal degrees, positive clockwise\n * @param {string} [units=kilometers] in which `distance` will be express; miles, kilometers, degrees, or radians\n * @param {number} [zTranslation=0] length of the vertical motion, same unit of distance\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} the translated GeoJSON object\n * @example\n * var poly = turf.polygon([[[0,29],[3.5,29],[2.5,32],[0,29]]]);\n * var translatedPoly = turf.transformTranslate(poly, 100, 35);\n *\n * //addToMap\n * var addToMap = [poly, translatedPoly];\n * translatedPoly.properties = {stroke: '#F00', 'stroke-width': 4};\n */\nmodule.exports = function (geojson, distance, direction, units, zTranslation, mutate) {\n // Input validation\n if (!geojson) throw new Error('geojson is required');\n if (distance === undefined || distance === null || isNaN(distance)) throw new Error('distance is required');\n if (zTranslation && typeof zTranslation !== 'number' && isNaN(zTranslation)) throw new Error('zTranslation is not a number');\n\n // Shortcut no-motion\n zTranslation = (zTranslation !== undefined) ? zTranslation : 0;\n if (distance === 0 && zTranslation === 0) return geojson;\n\n if (direction === undefined || direction === null || isNaN(direction)) throw new Error('direction is required');\n\n // Invert with negative distances\n if (distance < 0) {\n distance = -distance;\n direction = -direction;\n }\n\n // Clone geojson to avoid side effects\n if (mutate === false || mutate === undefined) geojson = JSON.parse(JSON.stringify(geojson));\n\n // Translate each coordinate\n coordEach(geojson, function (pointCoords) {\n var newCoords = getCoords(rhumbDestination(pointCoords, distance, direction, units));\n pointCoords[0] = newCoords[0];\n pointCoords[1] = newCoords[1];\n if (zTranslation && pointCoords.length === 3) pointCoords[2] += zTranslation;\n });\n return geojson;\n};\n","var helpers = require('@turf/helpers');\nvar inside = require('@turf/inside');\nvar lineIntersect = require('@turf/line-intersect');\nvar polyToLinestring = require('@turf/polygon-to-linestring');\nvar invariant = require('@turf/invariant');\nvar getGeom = invariant.getGeom;\nvar getGeomType = invariant.getGeomType;\n\n/**\n * Boolean-Crosses returns True if the intersection results in a geometry whose dimension is one less than\n * the maximum dimension of the two source geometries and the intersection set is interior to\n * both source geometries.\n *\n * Boolean-Crosses returns t (TRUE) for only multipoint/polygon, multipoint/linestring, linestring/linestring, linestring/polygon, and linestring/multipolygon comparisons.\n *\n * @name booleanCrosses\n * @param {Geometry|Feature} feature1 GeoJSON Feature or Geometry\n * @param {Geometry|Feature} feature2 GeoJSON Feature or Geometry\n * @returns {boolean} true/false\n * @example\n * var line1 = turf.lineString([[-2, 2], [4, 2]]);\n * var line2 = turf.lineString([[1, 1], [1, 2], [1, 3], [1, 4]]);\n *\n * var cross = turf.booleanCrosses(line1, line2);\n * //=true\n */\nmodule.exports = function (feature1, feature2) {\n var type1 = getGeomType(feature1);\n var type2 = getGeomType(feature2);\n var geom1 = getGeom(feature1);\n var geom2 = getGeom(feature2);\n\n switch (type1) {\n case 'MultiPoint':\n switch (type2) {\n case 'LineString':\n return doMultiPointAndLineStringCross(geom1, geom2);\n case 'Polygon':\n return doesMultiPointCrossPoly(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'LineString':\n switch (type2) {\n case 'MultiPoint': // An inverse operation\n return doMultiPointAndLineStringCross(geom2, geom1);\n case 'LineString':\n return doLineStringsCross(geom1, geom2);\n case 'Polygon':\n return doLineStringAndPolygonCross(geom1, geom2);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n case 'Polygon':\n switch (type2) {\n case 'MultiPoint': // An inverse operation\n return doesMultiPointCrossPoly(geom2, geom1);\n case 'LineString': // An inverse operation\n return doLineStringAndPolygonCross(geom2, geom1);\n default:\n throw new Error('feature2 ' + type2 + ' geometry not supported');\n }\n default:\n throw new Error('feature1 ' + type1 + ' geometry not supported');\n }\n};\n\nfunction doMultiPointAndLineStringCross(multiPoint, lineString) {\n var foundIntPoint = false;\n var foundExtPoint = false;\n var pointLength = multiPoint.coordinates.length;\n var i = 0;\n while (i < pointLength && !foundIntPoint && !foundExtPoint) {\n for (var i2 = 0; i2 < lineString.coordinates.length - 1; i2++) {\n var incEndVertices = true;\n if (i2 === 0 || i2 === lineString.coordinates.length - 2) {\n incEndVertices = false;\n }\n if (isPointOnLineSegment(lineString.coordinates[i2], lineString.coordinates[i2 + 1], multiPoint.coordinates[i], incEndVertices)) {\n foundIntPoint = true;\n } else {\n foundExtPoint = true;\n }\n }\n i++;\n }\n return foundIntPoint && foundExtPoint;\n}\n\nfunction doLineStringsCross(lineString1, lineString2) {\n var doLinesIntersect = lineIntersect(lineString1, lineString2);\n if (doLinesIntersect.features.length > 0) {\n for (var i = 0; i < lineString1.coordinates.length - 1; i++) {\n for (var i2 = 0; i2 < lineString2.coordinates.length - 1; i2++) {\n var incEndVertices = true;\n if (i2 === 0 || i2 === lineString2.coordinates.length - 2) {\n incEndVertices = false;\n }\n if (isPointOnLineSegment(lineString1.coordinates[i], lineString1.coordinates[i + 1], lineString2.coordinates[i2], incEndVertices)) {\n return true;\n }\n }\n }\n }\n return false;\n}\n\nfunction doLineStringAndPolygonCross(lineString, polygon) {\n var doLinesIntersect = lineIntersect(lineString, polyToLinestring(polygon));\n if (doLinesIntersect.features.length > 0) {\n return true;\n }\n return false;\n}\n\nfunction isPointInPoly(polygon, point) {\n return inside(point, polygon);\n}\n\nfunction doesMultiPointCrossPoly(multiPoint, polygon) {\n var foundIntPoint = false;\n var foundExtPoint = false;\n var pointLength = multiPoint.coordinates[0].length;\n var i = 0;\n while (i < pointLength && foundIntPoint && foundExtPoint) {\n if (isPointInPoly(polygon, helpers.point(multiPoint.coordinates[0][i]), true)) {\n foundIntPoint = true;\n } else {\n foundExtPoint = true;\n }\n i++;\n }\n\n return foundExtPoint && foundExtPoint;\n}\n\n/**\n * Is a point on a line segment\n * Only takes into account outer rings\n * See http://stackoverflow.com/a/4833823/1979085\n *\n * @private\n * @param {Array} lineSegmentStart coord pair of start of line\n * @param {Array} lineSegmentEnd coord pair of end of line\n * @param {Array} point coord pair of point to check\n * @param {boolean} incEnd whether the point is allowed to fall on the line ends\n * @returns {boolean} true/false\n */\nfunction isPointOnLineSegment(lineSegmentStart, lineSegmentEnd, point, incEnd) {\n var dxc = point[0] - lineSegmentStart[0];\n var dyc = point[1] - lineSegmentStart[1];\n var dxl = lineSegmentEnd[0] - lineSegmentStart[0];\n var dyl = lineSegmentEnd[1] - lineSegmentStart[1];\n var cross = dxc * dyl - dyc * dxl;\n if (cross !== 0) {\n return false;\n }\n if (incEnd) {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] <= point[0] && point[0] <= lineSegmentEnd[0] : lineSegmentEnd[0] <= point[0] && point[0] <= lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] <= point[1] && point[1] <= lineSegmentEnd[1] : lineSegmentEnd[1] <= point[1] && point[1] <= lineSegmentStart[1];\n } else {\n if (Math.abs(dxl) >= Math.abs(dyl)) {\n return dxl > 0 ? lineSegmentStart[0] < point[0] && point[0] < lineSegmentEnd[0] : lineSegmentEnd[0] < point[0] && point[0] < lineSegmentStart[0];\n }\n return dyl > 0 ? lineSegmentStart[1] < point[1] && point[1] < lineSegmentEnd[1] : lineSegmentEnd[1] < point[1] && point[1] < lineSegmentStart[1];\n }\n}\n","/**\n* @license get-closest https://github.com/cosmosio/get-closest\n*\n* The MIT License (MIT)\n*\n* Copyright (c) 2014-2017 Olivier Scherrer \n*/\n\"use strict\";\n\n/**\n * Get the closest number in an array\n * @param {Number} item the base number\n * @param {Array} array the array to search into\n * @param {Function} getDiff returns the difference between the base number and\n * and the currently read item in the array. The item which returned the smallest difference wins.\n * @private\n */\nfunction _getClosest(item, array, getDiff) {\n var closest,\n diff;\n\n if (!Array.isArray(array)) {\n throw new Error(\"Get closest expects an array as second argument\");\n }\n\n array.forEach(function (comparedItem, comparedItemIndex) {\n var thisDiff = getDiff(comparedItem, item);\n\n if (thisDiff >= 0 && (typeof diff == \"undefined\" || thisDiff < diff)) {\n diff = thisDiff;\n closest = comparedItemIndex;\n }\n });\n\n return closest;\n}\n\nmodule.exports = {\n\n /**\n * Get the closest number in an array given a base number\n * Example: closest(30, [20, 0, 50, 29]) will return 3 as 29 is the closest item\n * @param {Number} item the base number\n * @param {Array} array the array of numbers to search into\n * @returns {Number} the index of the closest item in the array\n */\n number: function closestNumber(item, array) {\n return _getClosest(item, array, function (comparedItem, item) {\n return Math.abs(comparedItem - item);\n });\n },\n\n /**\n * Get the closest greater number in an array given a base number\n * Example: closest(30, [20, 0, 50, 29]) will return 2 as 50 is the closest greater item\n * @param {Number} item the base number\n * @param {Array} array the array of numbers to search into\n * @returns {Number} the index of the closest item in the array\n */\n greaterNumber: function closestGreaterNumber(item, array) {\n return _getClosest(item, array, function (comparedItem, item) {\n return comparedItem - item;\n });\n },\n\n /**\n * Get the closest lower number in an array given a base number\n * Example: closest(30, [20, 0, 50, 29]) will return 0 as 20 is the closest lower item\n * @param {Number} item the base number\n * @param {Array} array the array of numbers to search into\n * @returns {Number} the index of the closest item in the array\n */\n lowerNumber: function closestLowerNumber(item, array) {\n return _getClosest(item, array, function (comparedItem, item) {\n return item - comparedItem;\n });\n },\n\n /**\n * Get the closest item in an array given a base item and a comparator function\n * Example (closest(\"lundi\", [\"mundi\", \"mardi\"], getLevenshteinDistance)) will return 0 for \"lundi\"\n * @param {*} item the base item\n * @param {Array} array an array of items\n * @param {Function} comparator a comparatof function to compare the items\n *\n * The function looks like:\n *\n * // comparedItem comes from the array\n * // baseItem is the item to compare the others to\n * // It returns a number\n * function comparator(comparedItem, baseItem) {\n * return comparedItem - baseItem;\n * }\n */\n custom: function closestCustom(item, array, comparator) {\n return _getClosest(item, array, comparator);\n }\n\n};\n","var render = function (_h,_vm) {var _c=_vm._c;return _c('i',{staticClass:\"fa\",class:[_vm.props.value === null ? 'fa-question' : _vm.props.value ? 'fa-check' : 'fa-close']})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./SimpleTableBoolean.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!./SimpleTableBoolean.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SimpleTableBoolean.vue?vue&type=template&id=376a24ea&lang=html&functional=true&\"\nimport script from \"./SimpleTableBoolean.vue?vue&type=script&lang=js&\"\nexport * from \"./SimpleTableBoolean.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 true,\n null,\n null,\n null\n \n)\n\nexport default component.exports","export default {\r\n props: {\r\n value: {},\r\n type: String\r\n },\r\n functional: true,\r\n render (h, context) {\r\n return h('span', context.props.value.map(value => value.name || value).join(', '))\r\n }\r\n}\r\n","import SimpleTableBoolean from './SimpleTableBoolean'\r\nimport SimpleTableStringArray from './SimpleTableStringArray'\r\nimport {format} from 'src/js/i18n/conversion'\r\n\r\nexport default {\r\n props: {\r\n value: {},\r\n type: String,\r\n formatString: String\r\n },\r\n functional: true,\r\n render (h, context) {\r\n const {value, type, formatString} = context.props\r\n\r\n if (Array.isArray(value)) {\r\n return h(SimpleTableStringArray, {props: {value, type}})\r\n } else if (typeof value === 'boolean' || type === 'boolean') {\r\n return h(SimpleTableBoolean, {props: {value}})\r\n } else if (value !== null && (typeof value === 'number' || type === 'number')) {\r\n return h('span', format(value, formatString))\r\n } else if (value !== null && (type === 'date' || type === 'datetime')) {\r\n return h('span', format(value, type))\r\n } else if (value && value.name) {\r\n return h('span', value.name)\r\n } else {\r\n return h('span', (value !== null && value !== undefined) ? value.toString() : '')\r\n }\r\n }\r\n}\r\n","/**\n * Returns a cloned copy of the passed GeoJSON Object, including possible 'Foreign Members'.\n * ~3-5x faster than the common JSON.parse + JSON.stringify combo method.\n *\n * @name clone\n * @param {GeoJSON} geojson GeoJSON Object\n * @returns {GeoJSON} cloned GeoJSON Object\n * @example\n * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]], {color: 'red'});\n *\n * var lineCloned = turf.clone(line);\n */\nmodule.exports = function (geojson) {\n if (!geojson) throw new Error('geojson is required');\n\n switch (geojson.type) {\n case 'Feature':\n return cloneFeature(geojson);\n case 'FeatureCollection':\n return cloneFeatureCollection(geojson);\n case 'Point':\n case 'LineString':\n case 'Polygon':\n case 'MultiPoint':\n case 'MultiLineString':\n case 'MultiPolygon':\n case 'GeometryCollection':\n return cloneGeometry(geojson);\n default:\n throw new Error('unknown GeoJSON type');\n }\n};\n\n/**\n * Clone Feature\n *\n * @private\n * @param {Feature} geojson GeoJSON Feature\n * @returns {Feature} cloned Feature\n */\nfunction cloneFeature(geojson) {\n var cloned = {type: 'Feature'};\n // Preserve Foreign Members\n Object.keys(geojson).forEach(function (key) {\n switch (key) {\n case 'type':\n case 'properties':\n case 'geometry':\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n // Add properties & geometry last\n cloned.properties = cloneProperties(geojson.properties);\n cloned.geometry = cloneGeometry(geojson.geometry);\n return cloned;\n}\n\n/**\n * Clone Properties\n *\n * @private\n * @param {Object} properties GeoJSON Properties\n * @returns {Object} cloned Properties\n */\nfunction cloneProperties(properties) {\n var cloned = {};\n if (!properties) return cloned;\n Object.keys(properties).forEach(function (key) {\n var value = properties[key];\n if (typeof value === 'object') {\n // handle Array\n if (value.length) cloned[key] = value.map(function (item) {\n return item;\n });\n // handle Object\n cloned[key] = cloneProperties(value);\n } else cloned[key] = value;\n });\n return cloned;\n}\n\n/**\n * Clone Feature Collection\n *\n * @private\n * @param {FeatureCollection} geojson GeoJSON Feature Collection\n * @returns {FeatureCollection} cloned Feature Collection\n */\nfunction cloneFeatureCollection(geojson) {\n var cloned = {type: 'FeatureCollection'};\n\n // Preserve Foreign Members\n Object.keys(geojson).forEach(function (key) {\n switch (key) {\n case 'type':\n case 'features':\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n // Add features\n cloned.features = geojson.features.map(function (feature) {\n return cloneFeature(feature);\n });\n return cloned;\n}\n\n/**\n * Clone Geometry\n *\n * @private\n * @param {Geometry} geometry GeoJSON Geometry\n * @returns {Geometry} cloned Geometry\n */\nfunction cloneGeometry(geometry) {\n var geom = {type: geometry.type};\n if (geometry.bbox) geom.bbox = geometry.bbox;\n\n if (geometry.type === 'GeometryCollection') {\n geom.geometries = geometry.geometries.map(function (geom) {\n return cloneGeometry(geom);\n });\n return geom;\n }\n geom.coordinates = deepSlice(geometry.coordinates);\n return geom;\n}\n\n/**\n * Deep Slice coordinates\n *\n * @private\n * @param {Coordinates} coords Coordinates\n * @returns {Coordinates} all coordinates sliced\n */\nfunction deepSlice(coords) {\n if (typeof coords[0] !== 'object') { return coords.slice(); }\n return coords.map(function (coord) {\n return deepSlice(coord);\n });\n}\n","import mod from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SatImageCard.vue?vue&type=style&index=0&id=99411b72&lang=scss&scoped=true&\"; export default mod; export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/index.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/lib/loader.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SatImageCard.vue?vue&type=style&index=0&id=99411b72&lang=scss&scoped=true&\"","var point = require('@turf/helpers').point;\nvar convex = require('@turf/convex');\nvar explode = require('@turf/explode');\nvar centroid = require('@turf/centroid');\nvar getCoord = require('@turf/invariant').getCoord;\nvar coordEach = require('@turf/meta').coordEach;\n\n/**\n * Takes any {@link Feature} or a {@link FeatureCollection} and returns its [center of mass](https://en.wikipedia.org/wiki/Center_of_mass) using this formula: [Centroid of Polygon](https://en.wikipedia.org/wiki/Centroid#Centroid_of_polygon).\n *\n * @name centerOfMass\n * @param {GeoJSON} geojson GeoJSON to be centered\n * @param {Object} [properties] an Object that is used as the {@link Feature}'s properties\n * @returns {Feature} the center of mass\n * @example\n * var polygon = turf.polygon([[[-81, 41], [-88, 36], [-84, 31], [-80, 33], [-77, 39], [-81, 41]]]);\n *\n * var center = turf.centerOfMass(polygon);\n *\n * //addToMap\n * var addToMap = [polygon, center]\n */\nfunction centerOfMass(geojson, properties) {\n var type = (geojson.geometry) ? geojson.geometry.type : geojson.type;\n\n switch (type) {\n case 'Point':\n return point(getCoord(geojson), properties);\n case 'Polygon':\n var coords = [];\n coordEach(geojson, function (coord) {\n coords.push(coord);\n });\n\n // First, we neutralize the feature (set it around coordinates [0,0]) to prevent rounding errors\n // We take any point to translate all the points around 0\n var centre = centroid(geojson, properties);\n var translation = centre.geometry.coordinates;\n var sx = 0;\n var sy = 0;\n var sArea = 0;\n var i, pi, pj, xi, xj, yi, yj, a;\n\n var neutralizedPoints = coords.map(function (point) {\n return [\n point[0] - translation[0],\n point[1] - translation[1]\n ];\n });\n\n for (i = 0; i < coords.length - 1; i++) {\n // pi is the current point\n pi = neutralizedPoints[i];\n xi = pi[0];\n yi = pi[1];\n\n // pj is the next point (pi+1)\n pj = neutralizedPoints[i + 1];\n xj = pj[0];\n yj = pj[1];\n\n // a is the common factor to compute the signed area and the final coordinates\n a = xi * yj - xj * yi;\n\n // sArea is the sum used to compute the signed area\n sArea += a;\n\n // sx and sy are the sums used to compute the final coordinates\n sx += (xi + xj) * a;\n sy += (yi + yj) * a;\n }\n\n // Shape has no area: fallback on turf.centroid\n if (sArea === 0) {\n return centre;\n } else {\n // Compute the signed area, and factorize 1/6A\n var area = sArea * 0.5;\n var areaFactor = 1 / (6 * area);\n\n // Compute the final coordinates, adding back the values that have been neutralized\n return point([\n translation[0] + areaFactor * sx,\n translation[1] + areaFactor * sy\n ], properties);\n }\n default:\n // Not a polygon: Compute the convex hull and work with that\n var hull = convex(explode(geojson));\n\n if (hull) {\n return centerOfMass(hull, properties);\n } else {\n // Hull is empty: fallback on the centroid\n return centroid(geojson, properties);\n }\n }\n}\n\nmodule.exports = centerOfMass;\n","var invariant = require('@turf/invariant');\nvar getCoords = invariant.getCoords;\nvar featureEach = require('@turf/meta').featureEach;\n\n/**\n * Takes a {@link Point} grid and returns a correspondent matrix {Array>}\n * of the 'property' values\n *\n * @name gridToMatrix\n * @param {FeatureCollection} grid of points\n * @param {string} [property='elevation'] the property name in `points` from which z-values will be pulled\n * @param {boolean} [flip=false] returns the matrix upside-down\n * @returns {Array>} matrix of property values\n * @example\n * var pointGrid = require('@turf/point-grid');\n * var extent = [-70.823364, -33.553984, -70.473175, -33.302986];\n * var cellSize = 3;\n * var grid = pointGrid(extent, cellSize);\n * // add a random property to each point between 0 and 60\n * for (var i = 0; i < grid.features.length; i++) {\n * grid.features[i].properties.elevation = (Math.random() * 60);\n * }\n * gridToMatrix(grid);\n * //= [\n * [ 1, 13, 10, 9, 10, 13, 18],\n * [34, 8, 5, 4, 5, 8, 13],\n * [10, 5, 2, 1, 2, 5, 4],\n * [ 0, 4, 56, 19, 1, 4, 9],\n * [10, 5, 2, 1, 2, 5, 10],\n * [57, 8, 5, 4, 5, 0, 57],\n * [ 3, 13, 10, 9, 5, 13, 18],\n * [18, 13, 10, 9, 78, 13, 18]\n * ]\n */\nmodule.exports = function (grid, property, flip) {\n // validation\n invariant.collectionOf(grid, 'Point', 'input must contain Points');\n property = property || 'elevation';\n\n var pointsMatrix = sortPointsByLatLng(grid, flip);\n\n var matrix = [];\n\n // create property matrix from sorted points\n // looping order matters here\n for (var r = 0; r < pointsMatrix.length; r++) {\n var pointRow = pointsMatrix[r];\n var row = [];\n for (var c = 0; c < pointRow.length; c++) {\n var point = pointRow[c];\n // property exist\n if (point.properties[property]) {\n row.push(point.properties[property]);\n } else {\n row.push(0);\n }\n }\n matrix.push(row);\n }\n\n return matrix;\n};\n\n/**\n * Sorts points by latitude and longitude, creating a 2-dimensional array of points\n *\n * @private\n * @param {FeatureCollection} points GeoJSON Point features\n * @param {boolean} [flip=false] returns the matrix upside-down\n * @returns {Array>} points by latitude and longitude\n */\nfunction sortPointsByLatLng(points, flip) {\n var pointsByLatitude = {};\n\n // divide points by rows with the same latitude\n featureEach(points, function (point) {\n var lat = getCoords(point)[1];\n if (!pointsByLatitude[lat]) { pointsByLatitude[lat] = []; }\n pointsByLatitude[lat].push(point);\n });\n\n // sort points (with the same latitude) by longitude\n var orderedRowsByLatitude = Object.keys(pointsByLatitude).map(function (lat) {\n var row = pointsByLatitude[lat];\n var rowOrderedByLongitude = row.sort(function (a, b) {\n return getCoords(a)[0] - getCoords(b)[0];\n });\n return rowOrderedByLongitude;\n });\n\n // sort rows (of points with the same latitude) by latitude\n var pointMatrix = orderedRowsByLatitude.sort(function (a, b) {\n if (flip) {\n return getCoords(a[0])[1] - getCoords(b[0])[1];\n } else {\n return getCoords(b[0])[1] - getCoords(a[0])[1];\n }\n });\n return pointMatrix;\n}\n","var helpers = require('@turf/helpers');\nvar getCoords = require('@turf/invariant').getCoords;\nvar flattenEach = require('@turf/meta').flattenEach;\nvar lineString = helpers.lineString;\nvar featureCollection = helpers.featureCollection;\n\n/**\n * Creates a {@link FeatureCollection} of 2-vertex {@link LineString} segments from a {@link LineString|(Multi)LineString} or {@link Polygon|(Multi)Polygon}.\n *\n * @name lineSegment\n * @param {Geometry|FeatureCollection|Feature} geojson GeoJSON Polygon or LineString\n * @returns {FeatureCollection} 2-vertex line segments\n * @example\n * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]);\n * var segments = turf.lineSegment(polygon);\n *\n * //addToMap\n * var addToMap = [polygon, segments]\n */\nmodule.exports = function (geojson) {\n if (!geojson) throw new Error('geojson is required');\n\n var results = [];\n flattenEach(geojson, function (feature) {\n lineSegment(feature, results);\n });\n return featureCollection(results);\n};\n\n/**\n * Line Segment\n *\n * @private\n * @param {Feature} geojson Line or polygon feature\n * @param {Array} results push to results\n * @returns {void}\n */\nfunction lineSegment(geojson, results) {\n var coords = [];\n var geometry = geojson.geometry;\n switch (geometry.type) {\n case 'Polygon':\n coords = getCoords(geometry);\n break;\n case 'LineString':\n coords = [getCoords(geometry)];\n }\n coords.forEach(function (coord) {\n var segments = createSegments(coord, geojson.properties);\n segments.forEach(function (segment) {\n segment.id = results.length;\n results.push(segment);\n });\n });\n}\n\n/**\n * Create Segments from LineString coordinates\n *\n * @private\n * @param {LineString} coords LineString coordinates\n * @param {*} properties GeoJSON properties\n * @returns {Array>} line segments\n */\nfunction createSegments(coords, properties) {\n var segments = [];\n coords.reduce(function (previousCoords, currentCoords) {\n var segment = lineString([previousCoords, currentCoords], properties);\n segment.bbox = bbox(previousCoords, currentCoords);\n segments.push(segment);\n return currentCoords;\n });\n return segments;\n}\n\n/**\n * Create BBox between two coordinates (faster than @turf/bbox)\n *\n * @private\n * @param {[number, number]} coords1 Point coordinate\n * @param {[number, number]} coords2 Point coordinate\n * @returns {BBox} [west, south, east, north]\n */\nfunction bbox(coords1, coords2) {\n var x1 = coords1[0];\n var y1 = coords1[1];\n var x2 = coords2[0];\n var y2 = coords2[1];\n var west = (x1 < x2) ? x1 : x2;\n var south = (y1 < y2) ? y1 : y2;\n var east = (x1 > x2) ? x1 : x2;\n var north = (y1 > y2) ? y1 : y2;\n return [west, south, east, north];\n}\n","/*!\n* @license GNU Affero General Public License.\n* Copyright (c) 2015, 2015 Ronny Lorenz \n* v. 1.2.0\n* https://github.com/RaumZeit/MarchingSquares.js\n*/\n\n(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define(['./marchingsquares-isobands', './marchingsquares-isocontours'], factory);\n } else if (typeof module === 'object' && module.exports) {\n // Node. Does not work with strict CommonJS, but\n // only CommonJS-like environments that support module.exports,\n // like Node.\n module.exports = factory(require('./marchingsquares-isobands'),require('./marchingsquares-isocontours'));\n } else {\n // Browser globals (root is window)\n root.MarchingSquaresJS = factory(\n (root.MarchingSquaresJS) ? root.MarchingSquaresJS.isoBands : null,\n (root.MarchingSquaresJS) ? root.MarchingSquaresJS.isoContours : null\n );\n }\n}(this, function (isoBands, isoContours) {\n return {\n isoBands : (typeof isoBands === 'function') ? isoBands : (((typeof isoBands === 'object') && (typeof isoBands.isoBands === 'function')) ? isoBands.isoBands : null),\n isoContours: (typeof isoContours === 'function') ? isoContours : (((typeof isoContours === 'object') && (typeof isoContours.isoContours === 'function')) ? isoContours.isoContours : null)\n };\n}));\n","var isects = require('geojson-polygon-self-intersections');\nvar helpers = require('@turf/helpers');\nvar inside = require('@turf/inside');\nvar area = require('@turf/area');\nvar rbush = require('rbush');\nvar debug = require('debug')('simplepolygon');\nvar debugAll = require('debug')('simplepolygon:all');\n\n/**\n* Takes a complex (i.e. self-intersecting) geojson polygon, and breaks it down into its composite simple, non-self-intersecting one-ring polygons.\n*\n* @module simplepolygon\n* @param {Feature} feature Input polygon. This polygon may be unconform the {@link https://en.wikipedia.org/wiki/Simple_Features|Simple Features standard} in the sense that it's inner and outer rings may cross-intersect or self-intersect, that the outer ring must not contain the optional inner rings and that the winding number must not be positive for the outer and negative for the inner rings.\n* @return {FeatureCollection} Feature collection containing the simple, non-self-intersecting one-ring polygon features that the complex polygon is composed of. These simple polygons have properties such as their parent polygon, winding number and net winding number.\n*\n* @example\n* var poly = {\n* \"type\": \"Feature\",\n* \"geometry\": {\n* \"type\": \"Polygon\",\n* \"coordinates\": [[[0,0],[2,0],[0,2],[2,2],[0,0]]]\n* }\n* };\n*\n* var result = simplepolygon(poly);\n*\n* // =result\n* // which will be a featureCollection of two polygons, one with coordinates [[[0,0],[2,0],[1,1],[0,0]]], parent -1, winding 1 and net winding 1, and one with coordinates [[[1,1],[0,2],[2,2],[1,1]]], parent -1, winding -1 and net winding -1\n*/\n\nmodule.exports = function(feature) {\n // Check input\n if (feature.type != \"Feature\") throw new Error(\"The input must a geojson object of type Feature\");\n if ((feature.geometry === undefined) || (feature.geometry == null)) throw new Error(\"The input must a geojson object with a non-empty geometry\");\n if (feature.geometry.type != \"Polygon\") throw new Error(\"The input must be a geojson Polygon\");\n\n // Process input\n var numRings = feature.geometry.coordinates.length;\n var vertices = [];\n for (var i = 0; i < numRings; i++) {\n var ring = feature.geometry.coordinates[i];\n if (!equalArrays(ring[0],ring[ring.length-1])) {\n ring.push(ring[0]) // Close input ring if it is not\n }\n vertices.push.apply(vertices,ring.slice(0,ring.length-1));\n }\n if (!isUnique(vertices)) throw new Error(\"The input polygon may not have duplicate vertices (except for the first and last vertex of each ring)\");\n var numvertices = vertices.length; // number of input ring vertices, with the last closing vertices not counted\n debug(\"Processing input\");\n\n // Compute self-intersections\n var selfIsectsData = isects(feature, function filterFn(isect, ring0, edge0, start0, end0, frac0, ring1, edge1, start1, end1, frac1, unique){\n return [isect, ring0, edge0, start0, end0, frac0, ring1, edge1, start1, end1, frac1, unique];\n });\n var numSelfIsect = selfIsectsData.length;\n debug(\"Computing self-intersections\");\n\n // If no self-intersections are found, the input rings are the output rings. Hence, we must only compute their winding numbers, net winding numbers and (since ohers rings could lie outside the first ring) parents.\n if (numSelfIsect == 0) {\n var outputFeatureArray = [];\n for(var i = 0; i < numRings; i++) {\n outputFeatureArray.push(helpers.polygon([feature.geometry.coordinates[i]],{parent: -1, winding: windingOfRing(feature.geometry.coordinates[i])}));\n }\n var output = helpers.featureCollection(outputFeatureArray)\n determineParents();\n setNetWinding();\n debugAll(\"No self-intersections found. Input rings are output rings. Computed winding numbers, net winding numbers and parents\");\n debug(\"Finishing without self-intersections\");\n return output;\n }\n\n // If self-intersections are found, we will compute the output rings with the help of two intermediate variables\n // First, we build the pseudo vertex list and intersection list\n // The Pseudo vertex list is an array with for each ring an array with for each edge an array containing the pseudo-vertices (as made by their constructor) that have this ring and edge as ringAndEdgeIn, sorted for each edge by their fractional distance on this edge. It's length hence equals numRings.\n var pseudoVtxListByRingAndEdge = [];\n // The intersection list is an array containing intersections (as made by their constructor). First all numvertices ring-vertex-intersections, then all self-intersections (intra- and inter-ring). The order of the latter is not important but is permanent once given.\n var isectList = [];\n // Adding ring-pseudo-vertices to pseudoVtxListByRingAndEdge and ring-vertex-intersections to isectList\n for (var i = 0; i < numRings; i++) {\n pseudoVtxListByRingAndEdge.push([]);\n for (var j = 0; j < feature.geometry.coordinates[i].length-1; j++) {\n // Each edge will feature one ring-pseudo-vertex in its array, on the last position. i.e. edge j features the ring-pseudo-vertex of the ring vertex j+1, which has ringAndEdgeIn = [i,j], on the last position.\n pseudoVtxListByRingAndEdge[i].push([new PseudoVtx(feature.geometry.coordinates[i][(j+1).modulo(feature.geometry.coordinates[i].length-1)], 1, [i, j], [i, (j+1).modulo(feature.geometry.coordinates[i].length-1)], undefined)]);\n // The first numvertices elements in isectList correspond to the ring-vertex-intersections\n isectList.push(new Isect(feature.geometry.coordinates[i][j], [i, (j-1).modulo(feature.geometry.coordinates[i].length-1)], [i, j], undefined, undefined, false, true));\n }\n }\n // Adding intersection-pseudo-vertices to pseudoVtxListByRingAndEdge and self-intersections to isectList\n for (var i = 0; i < numSelfIsect; i++) {\n // Adding intersection-pseudo-vertices made using selfIsectsData to pseudoVtxListByRingAndEdge's array corresponding to the incomming ring and edge\n pseudoVtxListByRingAndEdge[selfIsectsData[i][1]][selfIsectsData[i][2]].push(new PseudoVtx(selfIsectsData[i][0], selfIsectsData[i][5], [selfIsectsData[i][1], selfIsectsData[i][2]], [selfIsectsData[i][6], selfIsectsData[i][7]], undefined));\n // selfIsectsData contains double mentions of each intersection, but we only want to add them once to isectList\n if (selfIsectsData[i][11]) isectList.push(new Isect(selfIsectsData[i][0], [selfIsectsData[i][1], selfIsectsData[i][2]], [selfIsectsData[i][6], selfIsectsData[i][7]], undefined, undefined, true, true));\n }\n var numIsect = isectList.length;\n // Sort edge arrays of pseudoVtxListByRingAndEdge by the fractional distance 'param'\n for (var i = 0; i < pseudoVtxListByRingAndEdge.length; i++) {\n for (var j = 0; j < pseudoVtxListByRingAndEdge[i].length; j++) {\n pseudoVtxListByRingAndEdge[i][j].sort(function(a, b){ return (a.param < b.param) ? -1 : 1 ; } );\n }\n }\n debug(\"Setting up pseudoVtxListByRingAndEdge and isectList\");\n\n // Make a spatial index of intersections, in preperation for the following two steps\n allIsectsAsIsectRbushTreeItem = [];\n for (var i = 0; i < numIsect; i++) {\n allIsectsAsIsectRbushTreeItem.push({minX: isectList[i].coord[0], minY: isectList[i].coord[1], maxX: isectList[i].coord[0], maxY: isectList[i].coord[1], index: i}); // could pass isect: isectList[i], but not necessary\n }\n var isectRbushTree = rbush();\n isectRbushTree.load(allIsectsAsIsectRbushTreeItem);\n\n // Now we will teach each intersection in isectList which is the next intersection along both it's [ring, edge]'s, in two steps.\n // First, we find the next intersection for each pseudo-vertex in pseudoVtxListByRingAndEdge:\n // For each pseudovertex in pseudoVtxListByRingAndEdge (3 loops) look at the next pseudovertex on that edge and find the corresponding intersection by comparing coordinates\n for (var i = 0; i < pseudoVtxListByRingAndEdge.length; i++){\n for (var j = 0; j < pseudoVtxListByRingAndEdge[i].length; j++){\n for (var k = 0; k < pseudoVtxListByRingAndEdge[i][j].length; k++){\n var coordToFind;\n if (k == pseudoVtxListByRingAndEdge[i][j].length-1) { // If it's the last pseudoVertex on that edge, then the next pseudoVertex is the first one on the next edge of that ring.\n coordToFind = pseudoVtxListByRingAndEdge[i][(j+1).modulo(feature.geometry.coordinates[i].length-1)][0].coord;\n } else {\n coordToFind = pseudoVtxListByRingAndEdge[i][j][k+1].coord;\n }\n var IsectRbushTreeItemFound = isectRbushTree.search({minX: coordToFind[0], minY: coordToFind[1], maxX: coordToFind[0], maxY: coordToFind[1]})[0]; // We can take [0] of the result, because there is only one isect correponding to a pseudo-vertex\n pseudoVtxListByRingAndEdge[i][j][k].nxtIsectAlongEdgeIn = IsectRbushTreeItemFound.index;\n }\n }\n }\n debug(\"Computing nextIsect for pseudoVtxListByRingAndEdge\");\n\n // Second, we port this knowledge of the next intersection over to the intersections in isectList, by finding the intersection corresponding to each pseudo-vertex and copying the pseudo-vertex' knownledge of the next-intersection over to the intersection\n for (var i = 0; i < pseudoVtxListByRingAndEdge.length; i++){\n for (var j = 0; j < pseudoVtxListByRingAndEdge[i].length; j++){\n for (var k = 0; k < pseudoVtxListByRingAndEdge[i][j].length; k++){\n var coordToFind = pseudoVtxListByRingAndEdge[i][j][k].coord;\n var IsectRbushTreeItemFound = isectRbushTree.search({minX: coordToFind[0], minY: coordToFind[1], maxX: coordToFind[0], maxY: coordToFind[1]})[0]; // We can take [0] of the result, because there is only one isect correponding to a pseudo-vertex\n var l = IsectRbushTreeItemFound.index;\n if (l < numvertices) { // Special treatment at ring-vertices: we correct the misnaming that happened in the previous block, since ringAndEdgeOut = ringAndEdge2 for ring vertices.\n isectList[l].nxtIsectAlongRingAndEdge2 = pseudoVtxListByRingAndEdge[i][j][k].nxtIsectAlongEdgeIn;\n } else { // Port the knowledge of the next intersection from the pseudo-vertices to the intersections, depending on how the edges are labeled in the pseudo-vertex and intersection.\n if (equalArrays(isectList[l].ringAndEdge1, pseudoVtxListByRingAndEdge[i][j][k].ringAndEdgeIn)) {\n isectList[l].nxtIsectAlongRingAndEdge1 = pseudoVtxListByRingAndEdge[i][j][k].nxtIsectAlongEdgeIn;\n } else {\n isectList[l].nxtIsectAlongRingAndEdge2 = pseudoVtxListByRingAndEdge[i][j][k].nxtIsectAlongEdgeIn;\n }\n }\n }\n }\n }\n // This explains why, eventhough when we will walk away from an intersection, we will walk way from the corresponding pseudo-vertex along edgeOut, pseudo-vertices have the property 'nxtIsectAlongEdgeIn' in stead of some propery 'nxtPseudoVtxAlongEdgeOut'. This is because this property (which is easy to find out) is used in the above for nxtIsectAlongRingAndEdge1 and nxtIsectAlongRingAndEdge2!\n debug(\"Porting nextIsect to isectList\");\n\n // Before we start walking over the intersections to build the output rings, we prepare a queue that stores information on intersections we still have to deal with, and put at least one intersection in it.\n // This queue will contain information on intersections where we can start walking from once the current walk is finished, and its parent output ring (the smallest output ring it lies within, -1 if no parent or parent unknown yet) and its winding number (which we can already determine).\n var queue = []\n // For each output ring, add the ring-vertex-intersection with the smalles x-value (i.e. the left-most) as a start intersection. By choosing such an extremal intersections, we are sure to start at an intersection that is a convex vertex of its output ring. By adding them all to the queue, we are sure that no rings will be forgotten. If due to ring-intersections such an intersection will be encountered while walking, it will be removed from the queue.\n var i = 0;\n for (var j = 0; j < numRings; j++) {\n var leftIsect = i;\n for (var k = 0; k < feature.geometry.coordinates[j].length-1; k++) {\n if (isectList[i].coord[0] < isectList[leftIsect].coord[0]) {\n leftIsect = i;\n }\n i++;\n }\n // Compute winding at this left-most ring-vertex-intersection. We thus this by using our knowledge that this extremal vertex must be a convex vertex.\n // We first find the intersection before and after it, and then use them to determine the winding number of the corresponding output ring, since we know that an extremal vertex of a simple, non-self-intersecting ring is always convex, so the only reason it would not be is because the winding number we use to compute it is wrong\n var isectAfterLeftIsect = isectList[leftIsect].nxtIsectAlongRingAndEdge2;\n for (var k = 0; k < isectList.length; k++) {\n if ((isectList[k].nxtIsectAlongRingAndEdge1 == leftIsect) || (isectList[k].nxtIsectAlongRingAndEdge2 == leftIsect)) {\n var isectBeforeLeftIsect = k;\n break\n }\n }\n var windingAtIsect = isConvex([isectList[isectBeforeLeftIsect].coord,isectList[leftIsect].coord,isectList[isectAfterLeftIsect].coord],true) ? 1 : -1;\n\n queue.push({isect: leftIsect, parent: -1, winding: windingAtIsect})\n }\n // Sort the queue by the same criterion used to find the leftIsect: the left-most leftIsect must be last in the queue, such that it will be popped first, such that we will work from out to in regarding input rings. This assumtion is used when predicting the winding number and parent of a new queue member.\n queue.sort(function(a, b){ return (isectList[a.isect].coord > isectList[b.isect].coord) ? -1 : 1 });\n debugAll(\"Initial state of the queue: \" + JSON.stringify(queue));\n debug(\"Setting up queue\");\n\n // Initialise output\n var outputFeatureArray = [];\n\n // While the queue is not empty, take the last object (i.e. its intersection) out and start making an output ring by walking in the direction that has not been walked away over yet.\n while (queue.length>0) {\n // Get the last object out of the queue\n var popped = queue.pop();\n var startIsect = popped.isect;\n var currentOutputRingParent = popped.parent;\n var currentOutputRingWinding = popped.winding;\n // Make new output ring and add vertex from starting intersection\n var currentOutputRing = outputFeatureArray.length;\n var currentOutputRingCoords = [isectList[startIsect].coord];\n debugAll(\"# Starting output ring number \" + outputFeatureArray.length + \" with winding \" + currentOutputRingWinding + \" from intersection \" + startIsect);\n if (startIsect < numvertices) debugAll(\"This is a ring-vertex-intersections, which means this output ring does not touch existing output rings\");\n // Set up the variables used while walking over intersections: 'currentIsect', 'nxtIsect' and 'walkingRingAndEdge'\n var currentIsect = startIsect;\n if (isectList[startIsect].ringAndEdge1Walkable) {\n var walkingRingAndEdge = isectList[startIsect].ringAndEdge1;\n var nxtIsect = isectList[startIsect].nxtIsectAlongRingAndEdge1;\n } else {\n var walkingRingAndEdge = isectList[startIsect].ringAndEdge2;\n var nxtIsect = isectList[startIsect].nxtIsectAlongRingAndEdge2;\n }\n // While we have not arrived back at the same intersection, keep walking\n while (!equalArrays(isectList[startIsect].coord,isectList[nxtIsect].coord)){\n debugAll(\"Walking from intersection \" + currentIsect + \" to \" + nxtIsect + \" over ring \" + walkingRingAndEdge[0] + \" and edge \" + walkingRingAndEdge[1]);\n currentOutputRingCoords.push(isectList[nxtIsect].coord);\n debugAll(\"Adding intersection \" + nxtIsect + \" to current output ring\");\n // If the next intersection is queued, we can remove it, because we will go there now.\n var nxtIsectInQueue = undefined;\n for(var i = 0; i < queue.length; i++) { if (queue[i].isect == nxtIsect) {nxtIsectInQueue = i; break; } }\n if (nxtIsectInQueue != undefined) {\n debugAll(\"Removing intersection \" + nxtIsect + \" from queue\");\n queue.splice(nxtIsectInQueue,1);\n }\n // Arriving at this new intersection, we know which will be our next walking ring and edge (if we came from 1 we will walk away from 2 and vice versa),\n // So we can set it as our new walking ring and intersection and remember that we (will) have walked over it\n // If we have never walked away from this new intersection along the other ring and edge then we will soon do, add the intersection (and the parent wand winding number) to the queue\n // (We can predict the winding number and parent as follows: if the edge is convex, the other output ring started from there will have the alternate winding and lie outside of the current one, and thus have the same parent ring as the current ring. Otherwise, it will have the same winding number and lie inside of the current ring. We are, however, only sure of this of an output ring started from there does not enclose the current ring. This is why the initial queue's intersections must be sorted such that outer ones come out first.)\n // We then update the other two walking variables.\n if (equalArrays(walkingRingAndEdge,isectList[nxtIsect].ringAndEdge1)) {\n walkingRingAndEdge = isectList[nxtIsect].ringAndEdge2;\n isectList[nxtIsect].ringAndEdge2Walkable = false;\n if (isectList[nxtIsect].ringAndEdge1Walkable) {\n debugAll(\"Adding intersection \" + nxtIsect + \" to queue\");\n var pushing = {isect: nxtIsect};\n if (isConvex([isectList[currentIsect].coord, isectList[nxtIsect].coord, isectList[isectList[nxtIsect].nxtIsectAlongRingAndEdge2].coord],currentOutputRingWinding == 1)) {\n pushing.parent = currentOutputRingParent;\n pushing.winding = -currentOutputRingWinding;\n } else {\n pushing.parent = currentOutputRing;\n pushing.winding = currentOutputRingWinding;\n }\n queue.push(pushing);\n }\n currentIsect = nxtIsect;\n nxtIsect = isectList[nxtIsect].nxtIsectAlongRingAndEdge2;\n } else {\n walkingRingAndEdge = isectList[nxtIsect].ringAndEdge1;\n isectList[nxtIsect].ringAndEdge1Walkable = false;\n if (isectList[nxtIsect].ringAndEdge2Walkable) {\n debugAll(\"Adding intersection \" + nxtIsect + \" to queue\");\n var pushing = {isect: nxtIsect};\n if (isConvex([isectList[currentIsect].coord, isectList[nxtIsect].coord, isectList[isectList[nxtIsect].nxtIsectAlongRingAndEdge1].coord],currentOutputRingWinding == 1)) {\n pushing.parent = currentOutputRingParent;\n pushing.winding = -currentOutputRingWinding;\n } else {\n pushing.parent = currentOutputRing;\n pushing.winding = currentOutputRingWinding;\n }\n queue.push(pushing);\n }\n currentIsect = nxtIsect;\n nxtIsect = isectList[nxtIsect].nxtIsectAlongRingAndEdge1;\n }\n debugAll(\"Current state of the queue: \" + JSON.stringify(queue));\n }\n debugAll(\"Walking from intersection \" + currentIsect + \" to \" + nxtIsect + \" over ring \" + walkingRingAndEdge[0] + \" and edge \" + walkingRingAndEdge[1] + \" and closing ring\");\n // Close output ring\n currentOutputRingCoords.push(isectList[nxtIsect].coord);\n // Push output ring to output\n outputFeatureArray.push(helpers.polygon([currentOutputRingCoords],{index: currentOutputRing, parent: currentOutputRingParent, winding: currentOutputRingWinding, netWinding: undefined}));\n }\n\n var output = helpers.featureCollection(outputFeatureArray);\n debug(\"Walking\");\n\n determineParents();\n debug(\"Determining parents\");\n\n setNetWinding();\n debug(\"Setting winding number\");\n\n // These functions are also used if no intersections are found\n function determineParents() {\n var featuresWithoutParent = [];\n for (var i = 0; i < output.features.length; i++) {\n debugAll(\"Output ring \" + i + \" has parent \" + output.features[i].properties.parent);\n if (output.features[i].properties.parent == -1) featuresWithoutParent.push(i);\n }\n debugAll(\"The following output ring(s) have no parent: \" + featuresWithoutParent);\n if (featuresWithoutParent.length > 1) {\n for (var i = 0; i < featuresWithoutParent.length; i++) {\n var parent = -1;\n var parentArea = Infinity;\n for (var j = 0; j < output.features.length; j++) {\n if (featuresWithoutParent[i] == j) continue\n if (inside(helpers.point(output.features[featuresWithoutParent[i]].geometry.coordinates[0][0]), output.features[j], true)) {\n if (area(output.features[j]) < parentArea) {\n parent = j;\n debugAll(\"Ring \"+featuresWithoutParent[i]+\" lies inside output ring \"+j);\n }\n }\n }\n output.features[featuresWithoutParent[i]].properties.parent = parent;\n debugAll(\"Ring \"+featuresWithoutParent[i]+\" is assigned parent \"+parent);\n }\n }\n }\n\n function setNetWinding() {\n for (var i = 0; i < output.features.length; i++) {\n if (output.features[i].properties.parent == -1) {\n var netWinding = output.features[i].properties.winding\n output.features[i].properties.netWinding = netWinding;\n setNetWindingOfChildren(i,netWinding)\n }\n }\n }\n\n function setNetWindingOfChildren(parent,ParentNetWinding){\n for (var i = 0; i < output.features.length; i++) {\n if (output.features[i].properties.parent == parent){\n var netWinding = ParentNetWinding + output.features[i].properties.winding\n output.features[i].properties.netWinding = netWinding;\n setNetWindingOfChildren(i,netWinding)\n }\n }\n }\n\n debugAll(\"# Total of \" + output.features.length + \" rings\");\n\n return output;\n}\n\n\n\n// Constructor for (ring- or intersection-) pseudo-vertices.\nvar PseudoVtx = function (coord, param, ringAndEdgeIn, ringAndEdgeOut, nxtIsectAlongEdgeIn) {\n this.coord = coord; // [x,y] of this pseudo-vertex\n this.param = param; // fractional distance of this intersection on incomming edge\n this.ringAndEdgeIn = ringAndEdgeIn; // [ring index, edge index] of incomming edge\n this.ringAndEdgeOut = ringAndEdgeOut; // [ring index, edge index] of outgoing edge\n this.nxtIsectAlongEdgeIn = nxtIsectAlongEdgeIn; // The next intersection when following the incomming edge (so not when following ringAndEdgeOut!)\n}\n\n// Constructor for an intersection. There are two intersection-pseudo-vertices per self-intersection and one ring-pseudo-vertex per ring-vertex-intersection. Their labels 1 and 2 are not assigned a particular meaning but are permanent once given.\nvar Isect = function (coord, ringAndEdge1, ringAndEdge2, nxtIsectAlongRingAndEdge1, nxtIsectAlongRingAndEdge2, ringAndEdge1Walkable, ringAndEdge2Walkable) {\n this.coord = coord; // [x,y] of this intersection\n this.ringAndEdge1 = ringAndEdge1; // first edge of this intersection\n this.ringAndEdge2 = ringAndEdge2; // second edge of this intersection\n this.nxtIsectAlongRingAndEdge1 = nxtIsectAlongRingAndEdge1; // the next intersection when following ringAndEdge1\n this.nxtIsectAlongRingAndEdge2 = nxtIsectAlongRingAndEdge2; // the next intersection when following ringAndEdge2\n this.ringAndEdge1Walkable = ringAndEdge1Walkable; // May we (still) walk away from this intersection over ringAndEdge1?\n this.ringAndEdge2Walkable = ringAndEdge2Walkable; // May we (still) walk away from this intersection over ringAndEdge2?\n}\n\n// Function to determine if three consecutive points of a simple, non-self-intersecting ring make up a convex vertex, assuming the ring is right- or lefthanded\nfunction isConvex(pts, righthanded){\n // 'pts' is an [x,y] pair\n // 'righthanded' is a boolean\n if (typeof(righthanded) === 'undefined') righthanded = true;\n if (pts.length != 3) throw new Error(\"This function requires an array of three points [x,y]\");\n var d = (pts[1][0] - pts[0][0]) * (pts[2][1] - pts[0][1]) - (pts[1][1] - pts[0][1]) * (pts[2][0] - pts[0][0]);\n return (d >= 0) == righthanded;\n}\n\n// Function to compute winding of simple, non-self-intersecting ring\nfunction windingOfRing(ring){\n // 'ring' is an array of [x,y] pairs with the last equal to the first\n // Compute the winding number based on the vertex with the smallest x-value, it precessor and successor. An extremal vertex of a simple, non-self-intersecting ring is always convex, so the only reason it is not is because the winding number we use to compute it is wrong\n var leftVtx = 0;\n for (var i = 0; i < ring.length-1; i++) { if (ring[i][0] < ring[leftVtx][0]) leftVtx = i; }\n if (isConvex([ring[(leftVtx-1).modulo(ring.length-1)],ring[leftVtx],ring[(leftVtx+1).modulo(ring.length-1)]],true)) {\n var winding = 1;\n } else {\n var winding = -1;\n }\n return winding\n}\n\n// Function to compare Arrays of numbers. From http://stackoverflow.com/questions/7837456/how-to-compare-arrays-in-javascript\nfunction equalArrays(array1, array2) {\n // if the other array is a falsy value, return\n if (!array1 || !array2)\n return false;\n\n // compare lengths - can save a lot of time\n if (array1.length != array2.length)\n return false;\n\n for (var i = 0, l=array1.length; i < l; i++) {\n // Check if we have nested arrays\n if (array1[i] instanceof Array && array2[i] instanceof Array) {\n // recurse into the nested arrays\n if (!equalArrays(array1[i],array2[i]))\n return false;\n }\n else if (array1[i] != array2[i]) {\n // Warning - two different object instances will never be equal: {x:20} != {x:20}\n return false;\n }\n }\n return true;\n}\n\n// Fix Javascript modulo for negative number. From http://stackoverflow.com/questions/4467539/javascript-modulo-not-behaving\nNumber.prototype.modulo = function(n) {\n return ((this % n) + n) % n;\n}\n\n// Function to get array with only unique elements. From http://stackoverflow.com/questions/1960473/unique-values-in-an-array\nfunction getUnique(array) {\n var u = {}, a = [];\n for(var i = 0, l = array.length; i < l; ++i){\n if(u.hasOwnProperty(array[i])) {\n continue;\n }\n a.push(array[i]);\n u[array[i]] = 1;\n }\n return a;\n}\n\n// Function to check if array is unique (i.e. all unique elements, i.e. no duplicate elements)\nfunction isUnique(array) {\n var u = {}, a = [];\n var isUnique = 1;\n for(var i = 0, l = array.length; i < l; ++i){\n if(u.hasOwnProperty(array[i])) {\n isUnique = 0;\n break;\n }\n u[array[i]] = 1;\n }\n return isUnique;\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"module-root\"},[(_vm.ready)?_vm._t(\"default\"):_vm._e(),_c('Portal',{attrs:{\"to\":\"leftSidebar\"}},[(_vm.ready)?_vm._t(\"left\"):_vm._e(),_c('FrsLoadingIndicator',{attrs:{\"loading\":!_vm.loaded,\"error\":_vm.error}})],2),_c('FrsLoadingIndicator',{attrs:{\"loading\":!_vm.loaded,\"error\":_vm.error},scopedSlots:_vm._u([{key:\"error\",fn:function(){return [_c('IxButton',{attrs:{\"back\":\"\"},on:{\"click\":_vm.backToDashboard}},[_c('IxRes',[_vm._v(\"frs.buttons.moduleLoadFailed\")])],1)]},proxy:true}])})],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\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!./FrsModuleRoot.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!./FrsModuleRoot.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./FrsModuleRoot.vue?vue&type=template&id=7e864fa8&scoped=true&lang=html&\"\nimport script from \"./FrsModuleRoot.vue?vue&type=script&lang=js&\"\nexport * from \"./FrsModuleRoot.vue?vue&type=script&lang=js&\"\nimport style0 from \"./FrsModuleRoot.vue?vue&type=style&index=0&id=7e864fa8&lang=scss&scoped=true&\"\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 \"7e864fa8\",\n null\n \n)\n\nexport default component.exports","var meta = require('@turf/meta');\nvar centroid = require('@turf/centroid');\nvar invariant = require('@turf/invariant');\nvar rhumbBearing = require('@turf/rhumb-bearing');\nvar rhumbDistance = require('@turf/rhumb-distance');\nvar rhumbDestination = require('@turf/rhumb-destination');\nvar coordEach = meta.coordEach;\nvar getCoords = invariant.getCoords;\n\n/**\n * Rotates any geojson Feature or Geometry of a specified angle, around its `centroid` or a given `pivot` point;\n * all rotations follow the right-hand rule: https://en.wikipedia.org/wiki/Right-hand_rule\n *\n * @name transformRotate\n * @param {GeoJSON} geojson object to be rotated\n * @param {number} angle of rotation (along the vertical axis), from North in decimal degrees, negative clockwise\n * @param {Geometry|Feature|Array} [pivot=`centroid`] point around which the rotation will be performed\n * @param {boolean} [mutate=false] allows GeoJSON input to be mutated (significant performance increase if true)\n * @returns {GeoJSON} the rotated GeoJSON feature\n * @example\n * var poly = turf.polygon([[[0,29],[3.5,29],[2.5,32],[0,29]]]);\n * var rotatedPoly = turf.transformRotate(poly, 10, [0, 25]);\n *\n * //addToMap\n * var addToMap = [poly, rotatedPoly];\n * rotatedPoly.properties = {stroke: '#F00', 'stroke-width': 4};\n */\nmodule.exports = function (geojson, angle, pivot, mutate) {\n // Input validation\n if (!geojson) throw new Error('geojson is required');\n if (angle === undefined || angle === null || isNaN(angle)) throw new Error('angle is required');\n\n // Shortcut no-rotation\n if (angle === 0) return geojson;\n\n // Use centroid of GeoJSON if pivot is not provided\n if (!pivot) pivot = centroid(geojson);\n\n // Clone geojson to avoid side effects\n if (mutate === false || mutate === undefined) geojson = JSON.parse(JSON.stringify(geojson));\n\n // Rotate each coordinate\n coordEach(geojson, function (pointCoords) {\n var initialAngle = rhumbBearing(pivot, pointCoords);\n var finalAngle = initialAngle + angle;\n var distance = rhumbDistance(pivot, pointCoords);\n var newCoords = getCoords(rhumbDestination(pivot, distance, finalAngle));\n pointCoords[0] = newCoords[0];\n pointCoords[1] = newCoords[1];\n });\n return geojson;\n};\n","/**\n * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}.\n *\n * @name feature\n * @param {Geometry} geometry input geometry\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a GeoJSON Feature\n * @example\n * var geometry = {\n * \"type\": \"Point\",\n * \"coordinates\": [110, 50]\n * };\n *\n * var feature = turf.feature(geometry);\n *\n * //=feature\n */\nfunction feature(geometry, properties, bbox, id) {\n if (geometry === undefined) throw new Error('geometry is required');\n if (properties && properties.constructor !== Object) throw new Error('properties must be an Object');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n if (id && ['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');\n\n var feat = {type: 'Feature'};\n if (id) feat.id = id;\n if (bbox) feat.bbox = bbox;\n feat.properties = properties || {};\n feat.geometry = geometry;\n return feat;\n}\n\n/**\n * Creates a GeoJSON {@link Geometry} from a Geometry string type & coordinates.\n * For GeometryCollection type use `helpers.geometryCollection`\n *\n * @name geometry\n * @param {string} type Geometry Type\n * @param {Array} coordinates Coordinates\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @returns {Geometry} a GeoJSON Geometry\n * @example\n * var type = 'Point';\n * var coordinates = [110, 50];\n *\n * var geometry = turf.geometry(type, coordinates);\n *\n * //=geometry\n */\nfunction geometry(type, coordinates, bbox) {\n // Validation\n if (!type) throw new Error('type is required');\n if (!coordinates) throw new Error('coordinates is required');\n if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n\n var geom;\n switch (type) {\n case 'Point': geom = point(coordinates).geometry; break;\n case 'LineString': geom = lineString(coordinates).geometry; break;\n case 'Polygon': geom = polygon(coordinates).geometry; break;\n case 'MultiPoint': geom = multiPoint(coordinates).geometry; break;\n case 'MultiLineString': geom = multiLineString(coordinates).geometry; break;\n case 'MultiPolygon': geom = multiPolygon(coordinates).geometry; break;\n default: throw new Error(type + ' is invalid');\n }\n if (bbox) geom.bbox = bbox;\n return geom;\n}\n\n/**\n * Takes coordinates and properties (optional) and returns a new {@link Point} feature.\n *\n * @name point\n * @param {Array} coordinates longitude, latitude position (each in decimal degrees)\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a Point feature\n * @example\n * var point = turf.point([-75.343, 39.984]);\n *\n * //=point\n */\nfunction point(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length === undefined) throw new Error('Coordinates must be an array');\n if (coordinates.length < 2) throw new Error('Coordinates must be at least 2 numbers long');\n if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) throw new Error('Coordinates must contain numbers');\n\n return feature({\n type: 'Point',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Takes an array of LinearRings and optionally an {@link Object} with properties and returns a {@link Polygon} feature.\n *\n * @name polygon\n * @param {Array>>} coordinates an array of LinearRings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a Polygon feature\n * @throws {Error} throw an error if a LinearRing of the polygon has too few positions\n * or if a LinearRing of the Polygon does not have matching Positions at the beginning & end.\n * @example\n * var polygon = turf.polygon([[\n * [-2.275543, 53.464547],\n * [-2.275543, 53.489271],\n * [-2.215118, 53.489271],\n * [-2.215118, 53.464547],\n * [-2.275543, 53.464547]\n * ]], { name: 'poly1', population: 400});\n *\n * //=polygon\n */\nfunction polygon(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n for (var i = 0; i < coordinates.length; i++) {\n var ring = coordinates[i];\n if (ring.length < 4) {\n throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.');\n }\n for (var j = 0; j < ring[ring.length - 1].length; j++) {\n // Check if first point of Polygon contains two numbers\n if (i === 0 && j === 0 && !isNumber(ring[0][0]) || !isNumber(ring[0][1])) throw new Error('Coordinates must contain numbers');\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error('First and last Position are not equivalent.');\n }\n }\n }\n\n return feature({\n type: 'Polygon',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link LineString} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name lineString\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a LineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var linestring1 = turf.lineString([\n * [-21.964416, 64.148203],\n * [-21.956176, 64.141316],\n * [-21.93901, 64.135924],\n * [-21.927337, 64.136673]\n * ]);\n * var linestring2 = turf.lineString([\n * [-21.929054, 64.127985],\n * [-21.912918, 64.134726],\n * [-21.916007, 64.141016],\n * [-21.930084, 64.14446]\n * ], {name: 'line 1', distance: 145});\n *\n * //=linestring1\n *\n * //=linestring2\n */\nfunction lineString(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n if (coordinates.length < 2) throw new Error('Coordinates must be an array of two or more positions');\n // Check if first point of LineString contains two numbers\n if (!isNumber(coordinates[0][1]) || !isNumber(coordinates[0][1])) throw new Error('Coordinates must contain numbers');\n\n return feature({\n type: 'LineString',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}.\n *\n * @name featureCollection\n * @param {Feature[]} features input features\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {FeatureCollection} a FeatureCollection of input features\n * @example\n * var features = [\n * turf.point([-75.343, 39.984], {name: 'Location A'}),\n * turf.point([-75.833, 39.284], {name: 'Location B'}),\n * turf.point([-75.534, 39.123], {name: 'Location C'})\n * ];\n *\n * var collection = turf.featureCollection(features);\n *\n * //=collection\n */\nfunction featureCollection(features, bbox, id) {\n if (!features) throw new Error('No features passed');\n if (!Array.isArray(features)) throw new Error('features must be an Array');\n if (bbox && bbox.length !== 4) throw new Error('bbox must be an Array of 4 numbers');\n if (id && ['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');\n\n var fc = {type: 'FeatureCollection'};\n if (id) fc.id = id;\n if (bbox) fc.bbox = bbox;\n fc.features = features;\n return fc;\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiLineString\n * @param {Array>>} coordinates an array of LineStrings\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a MultiLineString feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiLine = turf.multiLineString([[[0,0],[10,10]]]);\n *\n * //=multiLine\n */\nfunction multiLineString(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiLineString',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPoint\n * @param {Array>} coordinates an array of Positions\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a MultiPoint feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPt = turf.multiPoint([[0,0],[10,10]]);\n *\n * //=multiPt\n */\nfunction multiPoint(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPoint',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name multiPolygon\n * @param {Array>>>} coordinates an array of Polygons\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a multipolygon feature\n * @throws {Error} if no coordinates are passed\n * @example\n * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]);\n *\n * //=multiPoly\n *\n */\nfunction multiPolygon(coordinates, properties, bbox, id) {\n if (!coordinates) throw new Error('No coordinates passed');\n\n return feature({\n type: 'MultiPolygon',\n coordinates: coordinates\n }, properties, bbox, id);\n}\n\n/**\n * Creates a {@link Feature} based on a\n * coordinate array. Properties can be added optionally.\n *\n * @name geometryCollection\n * @param {Array} geometries an array of GeoJSON Geometries\n * @param {Object} [properties={}] an Object of key-value pairs to add as properties\n * @param {Array} [bbox] BBox [west, south, east, north]\n * @param {string|number} [id] Identifier\n * @returns {Feature} a GeoJSON GeometryCollection Feature\n * @example\n * var pt = {\n * \"type\": \"Point\",\n * \"coordinates\": [100, 0]\n * };\n * var line = {\n * \"type\": \"LineString\",\n * \"coordinates\": [ [101, 0], [102, 1] ]\n * };\n * var collection = turf.geometryCollection([pt, line]);\n *\n * //=collection\n */\nfunction geometryCollection(geometries, properties, bbox, id) {\n if (!geometries) throw new Error('geometries is required');\n if (!Array.isArray(geometries)) throw new Error('geometries must be an Array');\n\n return feature({\n type: 'GeometryCollection',\n geometries: geometries\n }, properties, bbox, id);\n}\n\n// https://en.wikipedia.org/wiki/Great-circle_distance#Radius_for_spherical_Earth\nvar factors = {\n miles: 3960,\n nauticalmiles: 3441.145,\n degrees: 57.2957795,\n radians: 1,\n inches: 250905600,\n yards: 6969600,\n meters: 6373000,\n metres: 6373000,\n centimeters: 6.373e+8,\n centimetres: 6.373e+8,\n kilometers: 6373,\n kilometres: 6373,\n feet: 20908792.65\n};\n\nvar areaFactors = {\n kilometers: 0.000001,\n kilometres: 0.000001,\n meters: 1,\n metres: 1,\n centimetres: 10000,\n millimeter: 1000000,\n acres: 0.000247105,\n miles: 3.86e-7,\n yards: 1.195990046,\n feet: 10.763910417,\n inches: 1550.003100006\n};\n/**\n * Round number to precision\n *\n * @param {number} num Number\n * @param {number} [precision=0] Precision\n * @returns {number} rounded number\n * @example\n * turf.round(120.4321)\n * //=120\n *\n * turf.round(120.4321, 2)\n * //=120.43\n */\nfunction round(num, precision) {\n if (num === undefined || num === null || isNaN(num)) throw new Error('num is required');\n if (precision && !(precision >= 0)) throw new Error('precision must be a positive number');\n var multiplier = Math.pow(10, precision || 0);\n return Math.round(num * multiplier) / multiplier;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from radians to a more friendly unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name radiansToDistance\n * @param {number} radians in radians across the sphere\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} distance\n */\nfunction radiansToDistance(radians, units) {\n if (radians === undefined || radians === null) throw new Error('radians is required');\n\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error('units is invalid');\n return radians * factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into radians\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @name distanceToRadians\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} radians\n */\nfunction distanceToRadians(distance, units) {\n if (distance === undefined || distance === null) throw new Error('distance is required');\n\n var factor = factors[units || 'kilometers'];\n if (!factor) throw new Error('units is invalid');\n return distance / factor;\n}\n\n/**\n * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into degrees\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, centimeters, kilometres, feet\n *\n * @name distanceToDegrees\n * @param {number} distance in real units\n * @param {string} [units=kilometers] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers.\n * @returns {number} degrees\n */\nfunction distanceToDegrees(distance, units) {\n return radians2degrees(distanceToRadians(distance, units));\n}\n\n/**\n * Converts any bearing angle from the north line direction (positive clockwise)\n * and returns an angle between 0-360 degrees (positive clockwise), 0 being the north line\n *\n * @name bearingToAngle\n * @param {number} bearing angle, between -180 and +180 degrees\n * @returns {number} angle between 0 and 360 degrees\n */\nfunction bearingToAngle(bearing) {\n if (bearing === null || bearing === undefined) throw new Error('bearing is required');\n\n var angle = bearing % 360;\n if (angle < 0) angle += 360;\n return angle;\n}\n\n/**\n * Converts an angle in radians to degrees\n *\n * @name radians2degrees\n * @param {number} radians angle in radians\n * @returns {number} degrees between 0 and 360 degrees\n */\nfunction radians2degrees(radians) {\n if (radians === null || radians === undefined) throw new Error('radians is required');\n\n var degrees = radians % (2 * Math.PI);\n return degrees * 180 / Math.PI;\n}\n\n/**\n * Converts an angle in degrees to radians\n *\n * @name degrees2radians\n * @param {number} degrees angle between 0 and 360 degrees\n * @returns {number} angle in radians\n */\nfunction degrees2radians(degrees) {\n if (degrees === null || degrees === undefined) throw new Error('degrees is required');\n\n var radians = degrees % 360;\n return radians * Math.PI / 180;\n}\n\n\n/**\n * Converts a distance to the requested unit.\n * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet\n *\n * @param {number} distance to be converted\n * @param {string} originalUnit of the distance\n * @param {string} [finalUnit=kilometers] returned unit\n * @returns {number} the converted distance\n */\nfunction convertDistance(distance, originalUnit, finalUnit) {\n if (distance === null || distance === undefined) throw new Error('distance is required');\n if (!(distance >= 0)) throw new Error('distance must be a positive number');\n\n var convertedDistance = radiansToDistance(distanceToRadians(distance, originalUnit), finalUnit || 'kilometers');\n return convertedDistance;\n}\n\n/**\n * Converts a area to the requested unit.\n * Valid units: kilometers, kilometres, meters, metres, centimetres, millimeter, acre, mile, yard, foot, inch\n * @param {number} area to be converted\n * @param {string} [originalUnit=meters] of the distance\n * @param {string} [finalUnit=kilometers] returned unit\n * @returns {number} the converted distance\n */\nfunction convertArea(area, originalUnit, finalUnit) {\n if (area === null || area === undefined) throw new Error('area is required');\n if (!(area >= 0)) throw new Error('area must be a positive number');\n\n var startFactor = areaFactors[originalUnit || 'meters'];\n if (!startFactor) throw new Error('invalid original units');\n\n var finalFactor = areaFactors[finalUnit || 'kilometers'];\n if (!finalFactor) throw new Error('invalid final units');\n\n return (area / startFactor) * finalFactor;\n}\n\n/**\n * isNumber\n *\n * @param {*} num Number to validate\n * @returns {boolean} true/false\n * @example\n * turf.isNumber(123)\n * //=true\n * turf.isNumber('foo')\n * //=false\n */\nfunction isNumber(num) {\n return !isNaN(num) && num !== null && !Array.isArray(num);\n}\n\nmodule.exports = {\n feature: feature,\n geometry: geometry,\n featureCollection: featureCollection,\n geometryCollection: geometryCollection,\n point: point,\n multiPoint: multiPoint,\n lineString: lineString,\n multiLineString: multiLineString,\n polygon: polygon,\n multiPolygon: multiPolygon,\n radiansToDistance: radiansToDistance,\n distanceToRadians: distanceToRadians,\n distanceToDegrees: distanceToDegrees,\n radians2degrees: radians2degrees,\n degrees2radians: degrees2radians,\n bearingToAngle: bearingToAngle,\n convertDistance: convertDistance,\n convertArea: convertArea,\n round: round,\n isNumber: isNumber\n};\n","var meta = require('@turf/meta');\nvar helpers = require('@turf/helpers');\nvar getCoords = require('@turf/invariant').getCoords;\nvar intersection = require('./intersection');\nvar flattenEach = meta.flattenEach;\nvar lineString = helpers.lineString;\nvar multiLineString = helpers.multiLineString;\nvar distanceToDegrees = helpers.distanceToDegrees;\n\n/**\n * Takes a {@link LineString|line} and returns a {@link LineString|line} at offset by the specified distance.\n *\n * @name lineOffset\n * @param {Geometry|Feature} geojson input GeoJSON\n * @param {number} distance distance to offset the line (can be of negative value)\n * @param {string} [units=kilometers] can be degrees, radians, miles, kilometers, inches, yards, meters\n * @returns {Feature} Line offset from the input line\n * @example\n * var line = turf.lineString([[-83, 30], [-84, 36], [-78, 41]], { \"stroke\": \"#F00\" });\n *\n * var offsetLine = turf.lineOffset(line, 2, \"miles\");\n *\n * //addToMap\n * var addToMap = [offsetLine, line]\n * offsetLine.properties.stroke = \"#00F\"\n */\nmodule.exports = function (geojson, distance, units) {\n if (!geojson) throw new Error('geojson is required');\n if (distance === undefined || distance === null || isNaN(distance)) throw new Error('distance is required');\n var type = (geojson.type === 'Feature') ? geojson.geometry.type : geojson.type;\n var properties = geojson.properties;\n\n switch (type) {\n case 'LineString':\n return lineOffset(geojson, distance, units);\n case 'MultiLineString':\n var coords = [];\n flattenEach(geojson, function (feature) {\n coords.push(lineOffset(feature, distance, units).geometry.coordinates);\n });\n return multiLineString(coords, properties);\n default:\n throw new Error('geometry ' + type + ' is not supported');\n }\n};\n\n/**\n * Line Offset\n *\n * @private\n * @param {Geometry|Feature} line input line\n * @param {number} distance distance to offset the line (can be of negative value)\n * @param {string} [units=kilometers] units\n * @returns {Feature} Line offset from the input line\n */\nfunction lineOffset(line, distance, units) {\n var segments = [];\n var offsetDegrees = distanceToDegrees(distance, units);\n var coords = getCoords(line);\n var finalCoords = [];\n coords.forEach(function (currentCoords, index) {\n if (index !== coords.length - 1) {\n var segment = processSegment(currentCoords, coords[index + 1], offsetDegrees);\n segments.push(segment);\n if (index > 0) {\n var seg2Coords = segments[index - 1];\n var intersects = intersection(segment, seg2Coords);\n\n // Handling for line segments that aren't straight\n if (intersects !== false) {\n seg2Coords[1] = intersects;\n segment[0] = intersects;\n }\n\n finalCoords.push(seg2Coords[0]);\n if (index === coords.length - 2) {\n finalCoords.push(segment[0]);\n finalCoords.push(segment[1]);\n }\n }\n // Handling for lines that only have 1 segment\n if (coords.length === 2) {\n finalCoords.push(segment[0]);\n finalCoords.push(segment[1]);\n }\n }\n });\n return lineString(finalCoords, line.properties);\n}\n\n/**\n * Process Segment\n * Inspiration taken from http://stackoverflow.com/questions/2825412/draw-a-parallel-line\n *\n * @private\n * @param {Array} point1 Point coordinates\n * @param {Array} point2 Point coordinates\n * @param {number} offset Offset\n * @returns {Array>} offset points\n */\nfunction processSegment(point1, point2, offset) {\n var L = Math.sqrt((point1[0] - point2[0]) * (point1[0] - point2[0]) + (point1[1] - point2[1]) * (point1[1] - point2[1]));\n\n var out1x = point1[0] + offset * (point2[1] - point1[1]) / L;\n var out2x = point2[0] + offset * (point2[1] - point1[1]) / L;\n var out1y = point1[1] + offset * (point1[0] - point2[0]) / L;\n var out2y = point2[1] + offset * (point1[0] - point2[0]) / L;\n return [[out1x, out1y], [out2x, out2y]];\n}\n","/*!\n * Fuse.js v3.3.0 - Lightweight fuzzy-search (http://fusejs.io)\n * \n * Copyright (c) 2012-2017 Kirollos Risk (http://kiro.me)\n * All Rights Reserved. Apache Software License 2.0\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n */\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"Fuse\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Fuse\"] = factory();\n\telse\n\t\troot[\"Fuse\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 8);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = function (obj) {\n return !Array.isArray ? Object.prototype.toString.call(obj) === '[object Array]' : Array.isArray(obj);\n};\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar bitapRegexSearch = __webpack_require__(5);\nvar bitapSearch = __webpack_require__(7);\nvar patternAlphabet = __webpack_require__(4);\n\nvar Bitap = function () {\n function Bitap(pattern, _ref) {\n var _ref$location = _ref.location,\n location = _ref$location === undefined ? 0 : _ref$location,\n _ref$distance = _ref.distance,\n distance = _ref$distance === undefined ? 100 : _ref$distance,\n _ref$threshold = _ref.threshold,\n threshold = _ref$threshold === undefined ? 0.6 : _ref$threshold,\n _ref$maxPatternLength = _ref.maxPatternLength,\n maxPatternLength = _ref$maxPatternLength === undefined ? 32 : _ref$maxPatternLength,\n _ref$isCaseSensitive = _ref.isCaseSensitive,\n isCaseSensitive = _ref$isCaseSensitive === undefined ? false : _ref$isCaseSensitive,\n _ref$tokenSeparator = _ref.tokenSeparator,\n tokenSeparator = _ref$tokenSeparator === undefined ? / +/g : _ref$tokenSeparator,\n _ref$findAllMatches = _ref.findAllMatches,\n findAllMatches = _ref$findAllMatches === undefined ? false : _ref$findAllMatches,\n _ref$minMatchCharLeng = _ref.minMatchCharLength,\n minMatchCharLength = _ref$minMatchCharLeng === undefined ? 1 : _ref$minMatchCharLeng;\n\n _classCallCheck(this, Bitap);\n\n this.options = {\n location: location,\n distance: distance,\n threshold: threshold,\n maxPatternLength: maxPatternLength,\n isCaseSensitive: isCaseSensitive,\n tokenSeparator: tokenSeparator,\n findAllMatches: findAllMatches,\n minMatchCharLength: minMatchCharLength\n };\n\n this.pattern = this.options.isCaseSensitive ? pattern : pattern.toLowerCase();\n\n if (this.pattern.length <= maxPatternLength) {\n this.patternAlphabet = patternAlphabet(this.pattern);\n }\n }\n\n _createClass(Bitap, [{\n key: 'search',\n value: function search(text) {\n if (!this.options.isCaseSensitive) {\n text = text.toLowerCase();\n }\n\n // Exact match\n if (this.pattern === text) {\n return {\n isMatch: true,\n score: 0,\n matchedIndices: [[0, text.length - 1]]\n };\n }\n\n // When pattern length is greater than the machine word length, just do a a regex comparison\n var _options = this.options,\n maxPatternLength = _options.maxPatternLength,\n tokenSeparator = _options.tokenSeparator;\n\n if (this.pattern.length > maxPatternLength) {\n return bitapRegexSearch(text, this.pattern, tokenSeparator);\n }\n\n // Otherwise, use Bitap algorithm\n var _options2 = this.options,\n location = _options2.location,\n distance = _options2.distance,\n threshold = _options2.threshold,\n findAllMatches = _options2.findAllMatches,\n minMatchCharLength = _options2.minMatchCharLength;\n\n return bitapSearch(text, this.pattern, this.patternAlphabet, {\n location: location,\n distance: distance,\n threshold: threshold,\n findAllMatches: findAllMatches,\n minMatchCharLength: minMatchCharLength\n });\n }\n }]);\n\n return Bitap;\n}();\n\n// let x = new Bitap(\"od mn war\", {})\n// let result = x.search(\"Old Man's War\")\n// console.log(result)\n\nmodule.exports = Bitap;\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar isArray = __webpack_require__(0);\n\nvar deepValue = function deepValue(obj, path, list) {\n if (!path) {\n // If there's no path left, we've gotten to the object we care about.\n list.push(obj);\n } else {\n var dotIndex = path.indexOf('.');\n var firstSegment = path;\n var remaining = null;\n\n if (dotIndex !== -1) {\n firstSegment = path.slice(0, dotIndex);\n remaining = path.slice(dotIndex + 1);\n }\n\n var value = obj[firstSegment];\n\n if (value !== null && value !== undefined) {\n if (!remaining && (typeof value === 'string' || typeof value === 'number')) {\n list.push(value.toString());\n } else if (isArray(value)) {\n // Search each item in the array.\n for (var i = 0, len = value.length; i < len; i += 1) {\n deepValue(value[i], remaining, list);\n }\n } else if (remaining) {\n // An object. Recurse further.\n deepValue(value, remaining, list);\n }\n }\n }\n\n return list;\n};\n\nmodule.exports = function (obj, path) {\n return deepValue(obj, path, []);\n};\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = function () {\n var matchmask = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n var minMatchCharLength = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n\n var matchedIndices = [];\n var start = -1;\n var end = -1;\n var i = 0;\n\n for (var len = matchmask.length; i < len; i += 1) {\n var match = matchmask[i];\n if (match && start === -1) {\n start = i;\n } else if (!match && start !== -1) {\n end = i - 1;\n if (end - start + 1 >= minMatchCharLength) {\n matchedIndices.push([start, end]);\n }\n start = -1;\n }\n }\n\n // (i-1 - start) + 1 => i - start\n if (matchmask[i - 1] && i - start >= minMatchCharLength) {\n matchedIndices.push([start, i - 1]);\n }\n\n return matchedIndices;\n};\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = function (pattern) {\n var mask = {};\n var len = pattern.length;\n\n for (var i = 0; i < len; i += 1) {\n mask[pattern.charAt(i)] = 0;\n }\n\n for (var _i = 0; _i < len; _i += 1) {\n mask[pattern.charAt(_i)] |= 1 << len - _i - 1;\n }\n\n return mask;\n};\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar SPECIAL_CHARS_REGEX = /[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g;\n\nmodule.exports = function (text, pattern) {\n var tokenSeparator = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : / +/g;\n\n var regex = new RegExp(pattern.replace(SPECIAL_CHARS_REGEX, '\\\\$&').replace(tokenSeparator, '|'));\n var matches = text.match(regex);\n var isMatch = !!matches;\n var matchedIndices = [];\n\n if (isMatch) {\n for (var i = 0, matchesLen = matches.length; i < matchesLen; i += 1) {\n var match = matches[i];\n matchedIndices.push([text.indexOf(match), match.length - 1]);\n }\n }\n\n return {\n // TODO: revisit this score\n score: isMatch ? 0.5 : 1,\n isMatch: isMatch,\n matchedIndices: matchedIndices\n };\n};\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = function (pattern, _ref) {\n var _ref$errors = _ref.errors,\n errors = _ref$errors === undefined ? 0 : _ref$errors,\n _ref$currentLocation = _ref.currentLocation,\n currentLocation = _ref$currentLocation === undefined ? 0 : _ref$currentLocation,\n _ref$expectedLocation = _ref.expectedLocation,\n expectedLocation = _ref$expectedLocation === undefined ? 0 : _ref$expectedLocation,\n _ref$distance = _ref.distance,\n distance = _ref$distance === undefined ? 100 : _ref$distance;\n\n var accuracy = errors / pattern.length;\n var proximity = Math.abs(expectedLocation - currentLocation);\n\n if (!distance) {\n // Dodge divide by zero error.\n return proximity ? 1.0 : accuracy;\n }\n\n return accuracy + proximity / distance;\n};\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bitapScore = __webpack_require__(6);\nvar matchedIndices = __webpack_require__(3);\n\nmodule.exports = function (text, pattern, patternAlphabet, _ref) {\n var _ref$location = _ref.location,\n location = _ref$location === undefined ? 0 : _ref$location,\n _ref$distance = _ref.distance,\n distance = _ref$distance === undefined ? 100 : _ref$distance,\n _ref$threshold = _ref.threshold,\n threshold = _ref$threshold === undefined ? 0.6 : _ref$threshold,\n _ref$findAllMatches = _ref.findAllMatches,\n findAllMatches = _ref$findAllMatches === undefined ? false : _ref$findAllMatches,\n _ref$minMatchCharLeng = _ref.minMatchCharLength,\n minMatchCharLength = _ref$minMatchCharLeng === undefined ? 1 : _ref$minMatchCharLeng;\n\n var expectedLocation = location;\n // Set starting location at beginning text and initialize the alphabet.\n var textLen = text.length;\n // Highest score beyond which we give up.\n var currentThreshold = threshold;\n // Is there a nearby exact match? (speedup)\n var bestLocation = text.indexOf(pattern, expectedLocation);\n\n var patternLen = pattern.length;\n\n // a mask of the matches\n var matchMask = [];\n for (var i = 0; i < textLen; i += 1) {\n matchMask[i] = 0;\n }\n\n if (bestLocation !== -1) {\n var score = bitapScore(pattern, {\n errors: 0,\n currentLocation: bestLocation,\n expectedLocation: expectedLocation,\n distance: distance\n });\n currentThreshold = Math.min(score, currentThreshold);\n\n // What about in the other direction? (speed up)\n bestLocation = text.lastIndexOf(pattern, expectedLocation + patternLen);\n\n if (bestLocation !== -1) {\n var _score = bitapScore(pattern, {\n errors: 0,\n currentLocation: bestLocation,\n expectedLocation: expectedLocation,\n distance: distance\n });\n currentThreshold = Math.min(_score, currentThreshold);\n }\n }\n\n // Reset the best location\n bestLocation = -1;\n\n var lastBitArr = [];\n var finalScore = 1;\n var binMax = patternLen + textLen;\n\n var mask = 1 << patternLen - 1;\n\n for (var _i = 0; _i < patternLen; _i += 1) {\n // Scan for the best match; each iteration allows for one more error.\n // Run a binary search to determine how far from the match location we can stray\n // at this error level.\n var binMin = 0;\n var binMid = binMax;\n\n while (binMin < binMid) {\n var _score3 = bitapScore(pattern, {\n errors: _i,\n currentLocation: expectedLocation + binMid,\n expectedLocation: expectedLocation,\n distance: distance\n });\n\n if (_score3 <= currentThreshold) {\n binMin = binMid;\n } else {\n binMax = binMid;\n }\n\n binMid = Math.floor((binMax - binMin) / 2 + binMin);\n }\n\n // Use the result from this iteration as the maximum for the next.\n binMax = binMid;\n\n var start = Math.max(1, expectedLocation - binMid + 1);\n var finish = findAllMatches ? textLen : Math.min(expectedLocation + binMid, textLen) + patternLen;\n\n // Initialize the bit array\n var bitArr = Array(finish + 2);\n\n bitArr[finish + 1] = (1 << _i) - 1;\n\n for (var j = finish; j >= start; j -= 1) {\n var currentLocation = j - 1;\n var charMatch = patternAlphabet[text.charAt(currentLocation)];\n\n if (charMatch) {\n matchMask[currentLocation] = 1;\n }\n\n // First pass: exact match\n bitArr[j] = (bitArr[j + 1] << 1 | 1) & charMatch;\n\n // Subsequent passes: fuzzy match\n if (_i !== 0) {\n bitArr[j] |= (lastBitArr[j + 1] | lastBitArr[j]) << 1 | 1 | lastBitArr[j + 1];\n }\n\n if (bitArr[j] & mask) {\n finalScore = bitapScore(pattern, {\n errors: _i,\n currentLocation: currentLocation,\n expectedLocation: expectedLocation,\n distance: distance\n });\n\n // This match will almost certainly be better than any existing match.\n // But check anyway.\n if (finalScore <= currentThreshold) {\n // Indeed it is\n currentThreshold = finalScore;\n bestLocation = currentLocation;\n\n // Already passed `loc`, downhill from here on in.\n if (bestLocation <= expectedLocation) {\n break;\n }\n\n // When passing `bestLocation`, don't exceed our current distance from `expectedLocation`.\n start = Math.max(1, 2 * expectedLocation - bestLocation);\n }\n }\n }\n\n // No hope for a (better) match at greater error levels.\n var _score2 = bitapScore(pattern, {\n errors: _i + 1,\n currentLocation: expectedLocation,\n expectedLocation: expectedLocation,\n distance: distance\n });\n\n // console.log('score', score, finalScore)\n\n if (_score2 > currentThreshold) {\n break;\n }\n\n lastBitArr = bitArr;\n }\n\n // console.log('FINAL SCORE', finalScore)\n\n // Count exact matches (those with a score of 0) to be \"almost\" exact\n return {\n isMatch: bestLocation >= 0,\n score: finalScore === 0 ? 0.001 : finalScore,\n matchedIndices: matchedIndices(matchMask, minMatchCharLength)\n };\n};\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Bitap = __webpack_require__(1);\nvar deepValue = __webpack_require__(2);\nvar isArray = __webpack_require__(0);\n\nvar Fuse = function () {\n function Fuse(list, _ref) {\n var _ref$location = _ref.location,\n location = _ref$location === undefined ? 0 : _ref$location,\n _ref$distance = _ref.distance,\n distance = _ref$distance === undefined ? 100 : _ref$distance,\n _ref$threshold = _ref.threshold,\n threshold = _ref$threshold === undefined ? 0.6 : _ref$threshold,\n _ref$maxPatternLength = _ref.maxPatternLength,\n maxPatternLength = _ref$maxPatternLength === undefined ? 32 : _ref$maxPatternLength,\n _ref$caseSensitive = _ref.caseSensitive,\n caseSensitive = _ref$caseSensitive === undefined ? false : _ref$caseSensitive,\n _ref$tokenSeparator = _ref.tokenSeparator,\n tokenSeparator = _ref$tokenSeparator === undefined ? / +/g : _ref$tokenSeparator,\n _ref$findAllMatches = _ref.findAllMatches,\n findAllMatches = _ref$findAllMatches === undefined ? false : _ref$findAllMatches,\n _ref$minMatchCharLeng = _ref.minMatchCharLength,\n minMatchCharLength = _ref$minMatchCharLeng === undefined ? 1 : _ref$minMatchCharLeng,\n _ref$id = _ref.id,\n id = _ref$id === undefined ? null : _ref$id,\n _ref$keys = _ref.keys,\n keys = _ref$keys === undefined ? [] : _ref$keys,\n _ref$shouldSort = _ref.shouldSort,\n shouldSort = _ref$shouldSort === undefined ? true : _ref$shouldSort,\n _ref$getFn = _ref.getFn,\n getFn = _ref$getFn === undefined ? deepValue : _ref$getFn,\n _ref$sortFn = _ref.sortFn,\n sortFn = _ref$sortFn === undefined ? function (a, b) {\n return a.score - b.score;\n } : _ref$sortFn,\n _ref$tokenize = _ref.tokenize,\n tokenize = _ref$tokenize === undefined ? false : _ref$tokenize,\n _ref$matchAllTokens = _ref.matchAllTokens,\n matchAllTokens = _ref$matchAllTokens === undefined ? false : _ref$matchAllTokens,\n _ref$includeMatches = _ref.includeMatches,\n includeMatches = _ref$includeMatches === undefined ? false : _ref$includeMatches,\n _ref$includeScore = _ref.includeScore,\n includeScore = _ref$includeScore === undefined ? false : _ref$includeScore,\n _ref$verbose = _ref.verbose,\n verbose = _ref$verbose === undefined ? false : _ref$verbose;\n\n _classCallCheck(this, Fuse);\n\n this.options = {\n location: location,\n distance: distance,\n threshold: threshold,\n maxPatternLength: maxPatternLength,\n isCaseSensitive: caseSensitive,\n tokenSeparator: tokenSeparator,\n findAllMatches: findAllMatches,\n minMatchCharLength: minMatchCharLength,\n id: id,\n keys: keys,\n includeMatches: includeMatches,\n includeScore: includeScore,\n shouldSort: shouldSort,\n getFn: getFn,\n sortFn: sortFn,\n verbose: verbose,\n tokenize: tokenize,\n matchAllTokens: matchAllTokens\n };\n\n this.setCollection(list);\n }\n\n _createClass(Fuse, [{\n key: 'setCollection',\n value: function setCollection(list) {\n this.list = list;\n return list;\n }\n }, {\n key: 'search',\n value: function search(pattern) {\n this._log('---------\\nSearch pattern: \"' + pattern + '\"');\n\n var _prepareSearchers2 = this._prepareSearchers(pattern),\n tokenSearchers = _prepareSearchers2.tokenSearchers,\n fullSearcher = _prepareSearchers2.fullSearcher;\n\n var _search2 = this._search(tokenSearchers, fullSearcher),\n weights = _search2.weights,\n results = _search2.results;\n\n this._computeScore(weights, results);\n\n if (this.options.shouldSort) {\n this._sort(results);\n }\n\n return this._format(results);\n }\n }, {\n key: '_prepareSearchers',\n value: function _prepareSearchers() {\n var pattern = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n\n var tokenSearchers = [];\n\n if (this.options.tokenize) {\n // Tokenize on the separator\n var tokens = pattern.split(this.options.tokenSeparator);\n for (var i = 0, len = tokens.length; i < len; i += 1) {\n tokenSearchers.push(new Bitap(tokens[i], this.options));\n }\n }\n\n var fullSearcher = new Bitap(pattern, this.options);\n\n return { tokenSearchers: tokenSearchers, fullSearcher: fullSearcher };\n }\n }, {\n key: '_search',\n value: function _search() {\n var tokenSearchers = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n var fullSearcher = arguments[1];\n\n var list = this.list;\n var resultMap = {};\n var results = [];\n\n // Check the first item in the list, if it's a string, then we assume\n // that every item in the list is also a string, and thus it's a flattened array.\n if (typeof list[0] === 'string') {\n // Iterate over every item\n for (var i = 0, len = list.length; i < len; i += 1) {\n this._analyze({\n key: '',\n value: list[i],\n record: i,\n index: i\n }, {\n resultMap: resultMap,\n results: results,\n tokenSearchers: tokenSearchers,\n fullSearcher: fullSearcher\n });\n }\n\n return { weights: null, results: results };\n }\n\n // Otherwise, the first item is an Object (hopefully), and thus the searching\n // is done on the values of the keys of each item.\n var weights = {};\n for (var _i = 0, _len = list.length; _i < _len; _i += 1) {\n var item = list[_i];\n // Iterate over every key\n for (var j = 0, keysLen = this.options.keys.length; j < keysLen; j += 1) {\n var key = this.options.keys[j];\n if (typeof key !== 'string') {\n weights[key.name] = {\n weight: 1 - key.weight || 1\n };\n if (key.weight <= 0 || key.weight > 1) {\n throw new Error('Key weight has to be > 0 and <= 1');\n }\n key = key.name;\n } else {\n weights[key] = {\n weight: 1\n };\n }\n\n this._analyze({\n key: key,\n value: this.options.getFn(item, key),\n record: item,\n index: _i\n }, {\n resultMap: resultMap,\n results: results,\n tokenSearchers: tokenSearchers,\n fullSearcher: fullSearcher\n });\n }\n }\n\n return { weights: weights, results: results };\n }\n }, {\n key: '_analyze',\n value: function _analyze(_ref2, _ref3) {\n var key = _ref2.key,\n _ref2$arrayIndex = _ref2.arrayIndex,\n arrayIndex = _ref2$arrayIndex === undefined ? -1 : _ref2$arrayIndex,\n value = _ref2.value,\n record = _ref2.record,\n index = _ref2.index;\n var _ref3$tokenSearchers = _ref3.tokenSearchers,\n tokenSearchers = _ref3$tokenSearchers === undefined ? [] : _ref3$tokenSearchers,\n _ref3$fullSearcher = _ref3.fullSearcher,\n fullSearcher = _ref3$fullSearcher === undefined ? [] : _ref3$fullSearcher,\n _ref3$resultMap = _ref3.resultMap,\n resultMap = _ref3$resultMap === undefined ? {} : _ref3$resultMap,\n _ref3$results = _ref3.results,\n results = _ref3$results === undefined ? [] : _ref3$results;\n\n // Check if the texvaluet can be searched\n if (value === undefined || value === null) {\n return;\n }\n\n var exists = false;\n var averageScore = -1;\n var numTextMatches = 0;\n\n if (typeof value === 'string') {\n this._log('\\nKey: ' + (key === '' ? '-' : key));\n\n var mainSearchResult = fullSearcher.search(value);\n this._log('Full text: \"' + value + '\", score: ' + mainSearchResult.score);\n\n if (this.options.tokenize) {\n var words = value.split(this.options.tokenSeparator);\n var scores = [];\n\n for (var i = 0; i < tokenSearchers.length; i += 1) {\n var tokenSearcher = tokenSearchers[i];\n\n this._log('\\nPattern: \"' + tokenSearcher.pattern + '\"');\n\n // let tokenScores = []\n var hasMatchInText = false;\n\n for (var j = 0; j < words.length; j += 1) {\n var word = words[j];\n var tokenSearchResult = tokenSearcher.search(word);\n var obj = {};\n if (tokenSearchResult.isMatch) {\n obj[word] = tokenSearchResult.score;\n exists = true;\n hasMatchInText = true;\n scores.push(tokenSearchResult.score);\n } else {\n obj[word] = 1;\n if (!this.options.matchAllTokens) {\n scores.push(1);\n }\n }\n this._log('Token: \"' + word + '\", score: ' + obj[word]);\n // tokenScores.push(obj)\n }\n\n if (hasMatchInText) {\n numTextMatches += 1;\n }\n }\n\n averageScore = scores[0];\n var scoresLen = scores.length;\n for (var _i2 = 1; _i2 < scoresLen; _i2 += 1) {\n averageScore += scores[_i2];\n }\n averageScore = averageScore / scoresLen;\n\n this._log('Token score average:', averageScore);\n }\n\n var finalScore = mainSearchResult.score;\n if (averageScore > -1) {\n finalScore = (finalScore + averageScore) / 2;\n }\n\n this._log('Score average:', finalScore);\n\n var checkTextMatches = this.options.tokenize && this.options.matchAllTokens ? numTextMatches >= tokenSearchers.length : true;\n\n this._log('\\nCheck Matches: ' + checkTextMatches);\n\n // If a match is found, add the item to , including its score\n if ((exists || mainSearchResult.isMatch) && checkTextMatches) {\n // Check if the item already exists in our results\n var existingResult = resultMap[index];\n if (existingResult) {\n // Use the lowest score\n // existingResult.score, bitapResult.score\n existingResult.output.push({\n key: key,\n arrayIndex: arrayIndex,\n value: value,\n score: finalScore,\n matchedIndices: mainSearchResult.matchedIndices\n });\n } else {\n // Add it to the raw result list\n resultMap[index] = {\n item: record,\n output: [{\n key: key,\n arrayIndex: arrayIndex,\n value: value,\n score: finalScore,\n matchedIndices: mainSearchResult.matchedIndices\n }]\n };\n\n results.push(resultMap[index]);\n }\n }\n } else if (isArray(value)) {\n for (var _i3 = 0, len = value.length; _i3 < len; _i3 += 1) {\n this._analyze({\n key: key,\n arrayIndex: _i3,\n value: value[_i3],\n record: record,\n index: index\n }, {\n resultMap: resultMap,\n results: results,\n tokenSearchers: tokenSearchers,\n fullSearcher: fullSearcher\n });\n }\n }\n }\n }, {\n key: '_computeScore',\n value: function _computeScore(weights, results) {\n this._log('\\n\\nComputing score:\\n');\n\n for (var i = 0, len = results.length; i < len; i += 1) {\n var output = results[i].output;\n var scoreLen = output.length;\n\n var currScore = 1;\n var bestScore = 1;\n\n for (var j = 0; j < scoreLen; j += 1) {\n var weight = weights ? weights[output[j].key].weight : 1;\n var score = weight === 1 ? output[j].score : output[j].score || 0.001;\n var nScore = score * weight;\n\n if (weight !== 1) {\n bestScore = Math.min(bestScore, nScore);\n } else {\n output[j].nScore = nScore;\n currScore *= nScore;\n }\n }\n\n results[i].score = bestScore === 1 ? currScore : bestScore;\n\n this._log(results[i]);\n }\n }\n }, {\n key: '_sort',\n value: function _sort(results) {\n this._log('\\n\\nSorting....');\n results.sort(this.options.sortFn);\n }\n }, {\n key: '_format',\n value: function _format(results) {\n var finalOutput = [];\n\n if (this.options.verbose) {\n this._log('\\n\\nOutput:\\n\\n', JSON.stringify(results));\n }\n\n var transformers = [];\n\n if (this.options.includeMatches) {\n transformers.push(function (result, data) {\n var output = result.output;\n data.matches = [];\n\n for (var i = 0, len = output.length; i < len; i += 1) {\n var item = output[i];\n\n if (item.matchedIndices.length === 0) {\n continue;\n }\n\n var obj = {\n indices: item.matchedIndices,\n value: item.value\n };\n if (item.key) {\n obj.key = item.key;\n }\n if (item.hasOwnProperty('arrayIndex') && item.arrayIndex > -1) {\n obj.arrayIndex = item.arrayIndex;\n }\n data.matches.push(obj);\n }\n });\n }\n\n if (this.options.includeScore) {\n transformers.push(function (result, data) {\n data.score = result.score;\n });\n }\n\n for (var i = 0, len = results.length; i < len; i += 1) {\n var result = results[i];\n\n if (this.options.id) {\n result.item = this.options.getFn(result.item, this.options.id)[0];\n }\n\n if (!transformers.length) {\n finalOutput.push(result.item);\n continue;\n }\n\n var data = {\n item: result.item\n };\n\n for (var j = 0, _len2 = transformers.length; j < _len2; j += 1) {\n transformers[j](result, data);\n }\n\n finalOutput.push(data);\n }\n\n return finalOutput;\n }\n }, {\n key: '_log',\n value: function _log() {\n if (this.options.verbose) {\n var _console;\n\n (_console = console).log.apply(_console, arguments);\n }\n }\n }]);\n\n return Fuse;\n}();\n\nmodule.exports = Fuse;\n\n/***/ })\n/******/ ]);\n});\n//# sourceMappingURL=fuse.js.map"],"sourceRoot":""}