{"version":3,"sources":["webpack:///./node_modules/incremental-convex-hull/ich.js","webpack:///./node_modules/@turf/invariant/index.js","webpack:///./node_modules/lodash/_getRawTag.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/rbush/index.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/meta/index.js","webpack:///./node_modules/lodash/_baseKeys.js","webpack:///./node_modules/polygonize/dist/Graph.js","webpack:///./node_modules/geojson-equality/index.js","webpack:///./node_modules/lodash/stubFalse.js","webpack:///./node_modules/lodash/_arrayPush.js","webpack:///./node_modules/lodash/_isStrictComparable.js","webpack:///./node_modules/geodesy/osgridref.js","webpack:///./node_modules/lodash/_getNative.js","webpack:///./wwwroot/src/js/data/maize-sowing.js","webpack:///./node_modules/lodash/isBuffer.js","webpack:///./node_modules/robust-scale/robust-scale.js","webpack:///./node_modules/@turf/square/index.js","webpack:///./node_modules/geodesy/mgrs.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/part-edit-buffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/actions/algorithm.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/actions/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/lane-edit-buffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/index.js","webpack:///./node_modules/lodash/_isKeyable.js","webpack:///./node_modules/@turf/random/index.js","webpack:///./node_modules/lodash/isObjectLike.js","webpack:///./node_modules/lodash/_isMasked.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/lodash/_baseMatchesProperty.js","webpack:///./node_modules/lodash/_stringToPath.js","webpack:///./wwwroot/src/vue/areas/field-record-system/helpers/geojson/create-features.js","webpack:///./node_modules/@turf/planepoint/index.js","webpack:///./node_modules/convex-hull/ch.js","webpack:///./node_modules/lodash/isObject.js","webpack:///./node_modules/@turf/tin/index.js","webpack:///./node_modules/@turf/transform-scale/index.js","webpack:///./node_modules/lodash/_equalByTag.js","webpack:///./node_modules/lodash/_Promise.js","webpack:///./node_modules/lodash/_hashDelete.js","webpack:///./node_modules/convex-hull/lib/ch1d.js","webpack:///./node_modules/geojson-dissolve/node_modules/@turf/meta/index.js","webpack:///./node_modules/lodash/_mapCacheSet.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:///./node_modules/lodash/_matchesStrictComparable.js","webpack:///./node_modules/lodash/_memoizeCapped.js","webpack:///./node_modules/lodash/_baseForOwn.js","webpack:///./node_modules/lodash/_baseAggregator.js","webpack:///./node_modules/lodash/_Uint8Array.js","webpack:///./node_modules/lodash/_mapCacheGet.js","webpack:///./node_modules/simplicial-complex/topology.js","webpack:///./node_modules/lodash/_hashSet.js","webpack:///./node_modules/lodash/_baseIsArguments.js","webpack:///./node_modules/lodash/_baseHasIn.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/cultivation-planning/helpers.js","webpack:///./node_modules/lodash/_listCacheClear.js","webpack:///./node_modules/geojson-random/index.js","webpack:///./node_modules/lodash/_objectToString.js","webpack:///./node_modules/lodash/_root.js","webpack:///./node_modules/@turf/rhumb-destination/index.js","webpack:///./node_modules/lineclip/index.js","webpack:///./node_modules/lodash/_arrayFilter.js","webpack:///./node_modules/geodesy/latlon-vincenty.js","webpack:///./node_modules/@turf/boolean-disjoint/index.js","webpack:///./node_modules/lodash/_stackDelete.js","webpack:///./node_modules/lodash/isArrayLike.js","webpack:///./node_modules/@turf/projection/index.js","webpack:///./node_modules/deep-equal/lib/keys.js","webpack:///./node_modules/@turf/circle/index.js","webpack:///./node_modules/lodash/_getSymbols.js","webpack:///./node_modules/lodash/_baseIsNative.js","webpack:///./node_modules/debug/src/browser.js","webpack:///./node_modules/@turf/explode/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/basic-fertilization/oxidform-calculation.js","webpack:///./node_modules/lodash/_getValue.js","webpack:///./node_modules/lodash/_baseGetTag.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/lodash/_WeakMap.js","webpack:///./node_modules/@turf/boolean-overlap/index.js","webpack:///./node_modules/lodash/_defineProperty.js","webpack:///./node_modules/@turf/area/index.js","webpack:///./node_modules/@turf/within/index.js","webpack:///./node_modules/lodash/_getMatchData.js","webpack:///./node_modules/@turf/line-chunk/index.js","webpack:///./node_modules/workerize-loader/dist/rpc-wrapper.js","webpack:///./node_modules/geojson-utils/geojson-utils.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/lane-planning/helpers.js","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/lodash/_getMapData.js","webpack:///./node_modules/@turf/union/index.js","webpack:///./node_modules/lodash/_arraySome.js","webpack:///./node_modules/lodash/_getTag.js","webpack:///./node_modules/@turf/rhumb-distance/index.js","webpack:///./node_modules/polygonize/dist/EdgeRing.js","webpack:///./node_modules/lodash/_baseEach.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/application-maps/algorithm-definitions.js","webpack:///./node_modules/@turf/center/index.js","webpack:///./node_modules/@turf/concave/index.js","webpack:///./node_modules/lodash/_hashClear.js","webpack:///./node_modules/@turf/idw/index.js","webpack:///./node_modules/@turf/truncate/index.js","webpack:///./wwwroot/src/vue/areas/field-record-system/components/cultivation-overview/helpers.js","webpack:///./node_modules/lodash/_createAggregator.js","webpack:///./node_modules/lodash/_baseTimes.js","webpack:///./node_modules/@turf/bbox-polygon/index.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/center/index.js","webpack:///./node_modules/@turf/isolines/index.js","webpack:///./node_modules/lodash/_stackHas.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/areas/field-record-system/components/basic-fertilization/classification-calculation.js","webpack:///./node_modules/lodash/_nativeKeys.js","webpack:///./node_modules/lodash/_freeGlobal.js","webpack:///./node_modules/geojson-dissolve/index.js","webpack:///./node_modules/@turf/bbox-clip/index.js","webpack:///./node_modules/@turf/boolean-contains/index.js","webpack:///./node_modules/lodash/_ListCache.js","webpack:///./node_modules/@turf/polygon-tangents/index.js","webpack:///./node_modules/lodash/_nativeCreate.js","webpack:///./node_modules/quickselect/quickselect.js","webpack:///./node_modules/@turf/destination/index.js","webpack:///./node_modules/@turf/unkink-polygon/index.js","webpack:///./node_modules/geodesy/latlon-ellipsoidal.js","webpack:///./node_modules/lodash/_baseMatches.js","webpack:///./node_modules/wgs84/index.js","webpack:///./node_modules/lodash/_baseGet.js","webpack:///./node_modules/lodash/isArray.js","webpack:///./node_modules/lodash/_listCacheSet.js","webpack:///./node_modules/@turf/combine/index.js","webpack:///./node_modules/geojson-rbush/index.js","webpack:///./node_modules/lodash/_listCacheDelete.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/lodash/groupBy.js","webpack:///./node_modules/lodash/_arrayLikeKeys.js","webpack:///./node_modules/@turf/meta/index.js","webpack:///./node_modules/lodash/_baseFor.js","webpack:///./node_modules/lodash/isTypedArray.js","webpack:///./node_modules/lodash/_baseIsTypedArray.js","webpack:///./node_modules/lodash/toString.js","webpack:///./node_modules/@turf/midpoint/index.js","webpack:///./node_modules/@turf/polygon-to-linestring/index.js","webpack:///./node_modules/affine-hull/aff.js","webpack:///./node_modules/lodash/_arrayMap.js","webpack:///./node_modules/lodash/_Map.js","webpack:///./node_modules/lodash/_hashHas.js","webpack:///./node_modules/lodash/_MapCache.js","webpack:///./node_modules/lodash/_baseIsEqualDeep.js","webpack:///./node_modules/lodash/_mapCacheClear.js","webpack:///./node_modules/@turf/line-distance/index.js","webpack:///./node_modules/lodash/_baseGetAllKeys.js","webpack:///./node_modules/lodash/_Stack.js","webpack:///./node_modules/lodash/_setCacheAdd.js","webpack:///./node_modules/deep-equal/index.js","webpack:///./wwwroot/src/js/helpers/arrays.js","webpack:///./wwwroot/src/js/helpers/map-creation.js","webpack:///./node_modules/lodash/_stackGet.js","webpack:///./node_modules/@turf/line-slice/index.js","webpack:///./node_modules/@turf/dissolve/index.js","webpack:///./node_modules/lodash/hasIn.js","webpack:///./node_modules/@turf/inside/index.js","webpack:///./node_modules/lodash/_baseAssignValue.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/lodash/_overArg.js","webpack:///./node_modules/@turf/nearest/index.js","webpack:///./node_modules/robust-orientation/orientation.js","webpack:///./node_modules/geodesy/vector3d.js","webpack:///./node_modules/lodash/_mapCacheDelete.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/helpers/index.js","webpack:///./node_modules/lodash/_createBaseEach.js","webpack:///./node_modules/lodash/isFunction.js","webpack:///./node_modules/@turf/boolean-point-on-line/index.js","webpack:///./node_modules/lodash/eq.js","webpack:///./node_modules/lodash/_baseIsMatch.js","webpack:///./node_modules/debug/src/debug.js","webpack:///./node_modules/@turf/bezier/spline.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/area/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-overview/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-overview/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-overview/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-overview/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:///./wwwroot/src/js/store/modules/field-record-system/actions/process-field-wkts.worker.js","webpack:///./node_modules/lodash/_createBaseFor.js","webpack:///./node_modules/lodash/_nodeUtil.js","webpack:///./node_modules/@mapbox/geojson-area/index.js","webpack:///./node_modules/@turf/polygonize/index.js","webpack:///./node_modules/lodash/get.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/lodash/_Symbol.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/lodash/_arrayAggregator.js","webpack:///./node_modules/lodash/_equalArrays.js","webpack:///./node_modules/bit-twiddle/twiddle.js","webpack:///./node_modules/@turf/kinks/index.js","webpack:///./node_modules/lodash/_mapCacheHas.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:///./node_modules/lodash/_getAllKeys.js","webpack:///./node_modules/@turf/bearing/index.js","webpack:///./node_modules/@turf/mask/index.js","webpack:///./node_modules/lodash/_setToArray.js","webpack:///./node_modules/geodesy/latlon-vectors.js","webpack:///./node_modules/geojson-flatten/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/crop-rotation.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/workflows.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/navigation.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/layout.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/entity.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/master-data.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/user-data.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/zonemap.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/mutations/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/view-data-loading.js","webpack:///./wwwroot/src/js/helpers/vuex/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/master-data-loading.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/navigation.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/navigation-actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/crop-rotations.js","webpack:///./wwwroot/src/js/helpers/data-transformation.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/field-geometries.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/entity.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/user-data.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/weather.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/actions/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/navigation/index.js","webpack:///./wwwroot/src/js/helpers/geojson/simplification.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-planning/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-planning/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-planning/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-planning/edit-buffer.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/cultivation-planning/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/wizard-steps.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/wizard-actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/save-action.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/edit-action.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/edit-buffer/geometry-getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/edit-buffer/selection-getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/edit-buffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/machines/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/machines/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/machines/edit-buffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/machines/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/persons/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/persons/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/persons/editBuffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/persons/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/map/helpers.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/map/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/map/actions/focus.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/map/actions/geometry-editing-actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/map/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrient-requirement/edit-buffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrient-requirement/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrient-requirement/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrient-requirement/wizard-actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrient-requirement/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-creation/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-planning/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-planning/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-planning/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-export/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-export/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-import/process-probing-geometry.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/order-import/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/result-import/lab-presets.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/result-import/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/nutrient-maps/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps/flow-actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps/planned-yield-mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps-preview/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps-preview/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps-preview/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/application-maps-preview/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/basic-fertilization/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/field-details/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/field-details/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/field-details/editBuffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/field-details/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/company-data/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/company-data/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/company-data/editBuffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/company-data/getters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/company-data/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/nutrition-status/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/simple-application-maps/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/maize-sowing/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/soil-detail/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/soil-detail/editBuffer/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/soil-detail/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/entity-import/convert-to-tree.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/entity-import/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/default-yields/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/application-maps/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/download/convert-to-legacy-payload.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/download/get-kml-colors.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/download/valid-converters.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/download/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/data-import/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/data-import/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/data-import/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/telemetry/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/simon-module/mutations.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/simon-module/actions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/simon-module/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/migration/index.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/transitions.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/index.js","webpack:///./node_modules/@turf/along/index.js","webpack:///./node_modules/lodash/_baseUnary.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:///./node_modules/lodash/_equalObjects.js","webpack:///./node_modules/lodash/isLength.js","webpack:///./node_modules/@turf/line-intersect/index.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/invariant/index.js","webpack:///./node_modules/lodash/_listCacheGet.js","webpack:///./node_modules/lodash/_DataView.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:///./node_modules/lodash/_baseIteratee.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/helpers/index.js","webpack:///./node_modules/@turf/line-arc/index.js","webpack:///./node_modules/lodash/_hashGet.js","webpack:///./node_modules/@turf/tag/index.js","webpack:///./node_modules/two-product/two-product.js","webpack:///./node_modules/lodash/_baseIsEqual.js","webpack:///./node_modules/lodash/_isIndex.js","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/lodash/_cacheHas.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:///./node_modules/lodash/_Set.js","webpack:///./node_modules/polygonize/dist/Edge.js","webpack:///./wwwroot/src/js/store/modules/field-record-system/action/action-hierarchy.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/lodash/_assocIndexOf.js","webpack:///./node_modules/lodash/identity.js","webpack:///./node_modules/lodash/_baseToString.js","webpack:///./node_modules/@turf/line-overlap/index.js","webpack:///./node_modules/lodash/_stackSet.js","webpack:///./node_modules/two-sum/two-sum.js","webpack:///./node_modules/@turf/clean-coords/index.js","webpack:///./node_modules/lodash/stubArray.js","webpack:///./node_modules/lodash/isArguments.js","webpack:///./node_modules/geodesy/latlon-spherical.js","webpack:///./node_modules/@turf/rhumb-bearing/index.js","webpack:///./node_modules/lodash/_SetCache.js","webpack:///./node_modules/@turf/line-split/index.js","webpack:///./node_modules/lodash/_coreJsData.js","webpack:///./node_modules/polygonize/dist/util.js","webpack:///./node_modules/lodash/_setCacheHas.js","webpack:///./node_modules/lodash/_toSource.js","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/lodash/_Hash.js","webpack:///./node_modules/@turf/buffer/node_modules/@turf/center/node_modules/@turf/bbox/index.js","webpack:///./node_modules/lodash/_hasPath.js","webpack:///./node_modules/lodash/_castPath.js","webpack:///./node_modules/lodash/memoize.js","webpack:///./node_modules/lodash/_basePropertyDeep.js","webpack:///./node_modules/@turf/boolean-equal/index.js","webpack:///./node_modules/@turf/point-on-line/index.js","webpack:///./node_modules/lodash/_isPrototype.js","webpack:///./node_modules/@turf/isobands/node_modules/@turf/bbox/index.js","webpack:///./node_modules/@turf/boolean-within/index.js","webpack:///./node_modules/lodash/keys.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/lodash/_mapToArray.js","webpack:///./node_modules/get-closest/index.js","webpack:///./node_modules/lodash/_baseProperty.js","webpack:///./node_modules/lodash/_stackClear.js","webpack:///./node_modules/@turf/clone/index.js","webpack:///./node_modules/@turf/center-of-mass/index.js","webpack:///./node_modules/lodash/_toKey.js","webpack:///./node_modules/lodash/_isKey.js","webpack:///./node_modules/@turf/isolines/node_modules/grid-to-matrix/index.js","webpack:///./node_modules/lodash/property.js","webpack:///./node_modules/@turf/line-segment/index.js","webpack:///./node_modules/@turf/isolines/node_modules/marchingsquares/marchingsquares.js","webpack:///./node_modules/lodash/_listCacheHas.js","webpack:///./node_modules/simplepolygon/index.js","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/lodash/isSymbol.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","Symbol","objectProto","Object","hasOwnProperty","nativeObjectToString","toString","symToStringTag","toStringTag","getRawTag","isOwn","call","tag","unmasked","e","result","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","rbush","default","quickselect","maxEntries","format","_maxEntries","max","_minEntries","ceil","_initFormat","clear","findItem","item","items","equalsFn","calcBBox","node","toBBox","distBBox","children","p","destNode","createNode","minX","minY","maxX","maxY","child","extend","leaf","min","compareNodeMinX","compareNodeMinY","bboxArea","bboxMargin","enlargedArea","intersectionArea","contains","intersects","height","multiSelect","arr","left","right","compare","mid","stack","all","_all","data","search","bbox","len","childBBox","nodesToSearch","collides","load","_build","_splitRoot","tmpNode","_insert","remove","parent","goingUp","path","indexes","splice","_condense","compareMinX","compareMinY","toJSON","fromJSON","N","M","log","pow","right2","right3","N2","N1","_chooseSubtree","level","targetNode","area","enlargement","minArea","minEnlargement","isNode","insertPath","_split","_adjustParentBBoxes","m","_chooseSplitAxis","splitIndex","_chooseSplitIndex","newNode","bbox1","bbox2","overlap","minOverlap","xMargin","_allDistMargin","yMargin","leftBBox","rightBBox","margin","siblings","compareArr","featureIndex","geometryIndex","coordIndex","featureSubIndex","geomType","currentCoord","geometryProperties","forEach","coordinate","flattenReduce","segmentEach","previousCoords","currentSegment","segmentReduce","currentSubIndex","lineEach","subIndex","multi","ring","lineReduce","currentLine","lineIndex","lineSubIndex","isPrototype","nativeKeys","baseKeys","object","key","_createClass","defineProperties","target","props","descriptor","enumerable","configurable","writable","defineProperty","Constructor","protoProps","staticProps","_classCallCheck","instance","TypeError","Node","Edge","EdgeRing","_require","_require2","validateGeoJson","geoJson","Graph","edges","nodes","id","buildId","from","to","edge","symetricEdge","getSymetric","graph","cur","start","getNode","end","addEdge","_this","keys","_removeIfDangle","_this2","innerEdges","outerNodes","getOuterEdges","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","obj1","obj2","strict","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","stubFalse","arrayPush","array","values","offset","isObject","isStrictComparable","LatLon","OsGridRef","easting","northing","Number","latLonToOsGrid","datum","OSGB36","convertDatum","φ","lat","toRadians","λ","lon","F0","φ0","λ0","N0","E0","e2","n2","n3","cosφ","cos","sinφ","sin","ν","ρ","η2","Ma","Mb","Mc","Md","cos3φ","cos5φ","tan2φ","tan","tan4φ","I","II","III","IIIA","IV","V","VI","Δλ","Δλ2","Δλ3","Δλ4","Δλ5","Δλ6","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","digits","isNaN","RangeError","eInt","eDec","nInt","nDec","ePad","nPad","e100k","n100k","letterPair","fromCharCode","baseIsNative","getValue","getNative","waterLevels","soilQualities","usageModifiers","grain","silo","biogas","usages","root","freeExports","nodeType","freeModule","moduleExports","Buffer","nativeIsBuffer","isBuffer","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","defaults","wkt","depth","headlandLanes","segmentationResult","selectedSegments","headlands","isHeadlandGenerated","generatedHeadlandLane","segmentLaneTypes","candidateLanes","selectedLane","skip","subStep","abSegments","selectedAbSegment","checkValidity","state","partialState","console","error","part_edit_buffer","namespaced","mutations","_objectSpread","makeSetters","selectAllSegments","deselectAllSegments","set","partData","assign","reset","actions","findAndSetSelectedSegments","_ref","segmentIds","commit","segmentFeatures","rootGetters","makeSegmentFeatures","find","segmentIndex","_feature$properties","ringIndex","setAndClearDependentData","getSegmentation","_x","_getSegmentation","arguments","_callee","_ref2","regeneratorRuntime","wrap","_context","abrupt","smarterGet","expiry","inputs","fieldId","partFieldIndex","laneEditBuffer","selectedPartIndex","totalFieldPartCount","fieldParts","onResult","segmentation","booleanEqual","autoSegmentation","_x2","_autoSegmentation","_callee2","_ref3","turningCircle","_context2","partEditBuffer","minTurnRadius","border","smarterPost","then","getHeadland","_x3","_getHeadland","_callee3","_ref4","_state$laneEditBuffer2","maxIntoField","gap","workingWidth","_state$partEditBuffer3","_context3","dispatch","turnRadius","maxExtensionIntoField","laneWidth","headlandsResult","lanes","getABLines","_x4","_getABLines","_callee4","_ref5","_state$laneEditBuffer3","minLaneLength","maxLanes","_state$partEditBuffer4","selectedABSegments","_context4","width","minLength","maximumSets","newAbLine","_ref6","abindex","selectedAbIndex","findIndex","abLineString","segmentData","rawLine","newAbLane","oldAbSegment","newAbSegments","abSegmentCount","newSegmentIndex","toConsumableArray","globalSegmentIndex","copyCount","includes","computed","lineType","arrayIndex","moveLine","_ref7","newAbSegment","moveLines","_ref8","_state$laneEditBuffer","_state$partEditBuffer","laneCandidate","laneType","newCandidate","newCandidateLanes","splitOrJoinSegment","_ref9","_state$partEditBuffer2","saveSegmentation","_ref10","resetSegmentation","_ref11","loadPrerequisiteDataForPlanning","Promise","loadPrerequisiteDataForOverview","_loadPrerequisiteDataForOverview","startPlanning","savedPlan","rootState","fieldWkt","_savedPlan$settings","settings","partialFields","partialField","lane","fieldPartTemplate","actions_objectSpread","fieldPartDefaults","headland","templatePlan","machine","vehicle","fieldRecordSystem","machines","fieldGeometry","setFieldParts","wkts","makeFeature","splitToPolygons","toWkt","startPlanningPart","finishPart","_finishPart","getters","nextPart","_args2","isPlanningProfileAB","cancelPart","finishPlanning","_finishPlanning","finished","stopPlanning","startEditingFieldGeometry","commitEditedFieldGeometry","_ref12","undo","notifications","info","saveLanePlanAb","_ref13","userSettings","entityId","generatedAt","moment","toISOString","plans","_iteratorNormalCompletion","_didIteratorError","_iteratorError","_step","fieldPart","segmentGeometries","reduce","s","plan","segment","Id","harvestYear","partialFieldId","fieldPartGeometry","stringify","multiLineString","abLineId","computeSize","abLine","_iterator","iterator","done","err","return","acc","selectedLanePlans","saveLanePlan","_ref14","field","lanePlanNamesField","lanePlanNamesForField","fieldName","workingWidthName","laneTypeName","createPlanName","machineId","planId","targetSystem","_iteratorNormalCompletion2","_didIteratorError2","_iteratorError2","_step2","_iterator2","laneGeometry","headlandId","suggestion","lineGeometries","lines","totalDistance","turnsPerDistance","warnings","laneId","flatten","getDataForStepLaneSelection","_getDataForStepLaneSelection","_ref15","isAB","getLanePlanNamesForField","_ref16","lanePlanNames","getLanePlansForField","_ref17","lanePlans","getLanePlansForOrgUnit","_x5","_getLanePlansForOrgUnit","_callee5","_ref18","_context5","orgUnitId","_ref24","_ref25","slicedToArray","abLanePlans","download","_ref19","lanePlanIds","fileName","generateFileName","planIds","includeBorder","isBorderSelected","includeHeadland","isHeadlandSelected","includeHeadlandLanes","isHeadlandLanesSelected","includeInfieldLanes","includeBorderAsCurve","ui","selection","response","window","location","href","pathname","orgUnitName","entityLookup","lanePlansOrgUnit","date","utc","add","i18n","translations","formerName","abType","resetLanePlansSelection","_ref20","deleteLanePlans","_ref21","axios","delete","updateLanePlanName","_ref22","_ref23","previousName","put","catch","mutations_objectSpread","setIsCreateAbLineActive","active","isCreateAbLineActive","hideFooter","setLanePlansForField","lanePlansField","lanePlan","Vue","setSelectedPlanId","setLanePlans","setLanePlanId","JSON","setSelectedLanePlan","selectedPlan","setLanePlansOrgUnit","groupBy","totalNumberOfPlans","addLanePlansOrgUnit","lookup","_lookup$key","expandedNodes","selectedNodes","toggleExpanded","toggleSelected","wizardActive","globalSegmentIndicesForCandidateLanes","canSave","abLinesAvailable","linesAvailable","tree","orgUnit","cloneNode","lanePlansForNode","content","getters_objectSpread","selected","expanded","localeCompare","clone","availableMachines","toObject","planningProfile","moreFieldPartsExist","isOneFileSelected","setMachineParameters","laneData","lane_edit_buffer","lane_edit_buffer_objectSpread","setMachineData","planningProfiles","targetSystems","isFromDetailsView","planning","step","partialFieldFeatures","headlandFeatures","headlandLaneFeatures","laneFeatures","__webpack_exports__","modules","isKeyable","options","polygon","num_vertices","max_radial_length","isObjectLike","coreJsData","maskSrcKey","uid","exec","IE_PROTO","isMasked","func","__WEBPACK_AMD_DEFINE_ARRAY__","__WEBPACK_AMD_DEFINE_RESULT__","factory","isoContours","defaultSettings","successCallback","verbose","threshold","optionKeys","val","ret","ContourGrid2Paths","computeContourGrid","interpolateX","y0","rows","cols","ContourGrid","cval","tl","tr","br","bl","top","bottom","flipped","average","isSaddle","isTrivial","clearCell","getXY","grid","paths","path_idx","epsilon","gg","tracePath","merged","abs","unshift","dx","dy","maxj","dxContour","dyContour","nextEdge","currentCell","prev_cval","orientationIndex","outerEdges","outerEdgesSorted","aNode","bNode","det","d1","d2","sortOuterEdges","h","str","parseFloat","toLowerCase","fmtShort","ms","round","fmtLong","plural","long","mutate","d3","jsts","meta","center","helpers","turfBbox","projection","toWgs84","toMercator","radiansToDistance","distanceToRadians","buffer","radius","units","steps","projected","buffered","needsTransverseMercator","defineProjection","projectCoords","reader","io","GeoJSONReader","read","writer","GeoJSONWriter","write","coordsIsNaN","unprojectCoords","invert","rotate","geoTransverseMercator","multiBuffered","baseIsEqual","get","hasIn","isKey","matchesStrictComparable","toKey","COMPARE_PARTIAL_FLAG","COMPARE_UNORDERED_FLAG","baseMatchesProperty","srcValue","objValue","memoizeCapped","rePropName","reEscapeChar","stringToPath","string","number","quote","subString","fromFields","fields","fieldDataLookup","invariant","triangle","outer","z1","z2","x3","y3","z3","z","convexHull1d","convexHull2d","convexHullnd","convexHull","featurecollection","Triangle","A","B","C","D","F","G","r","byX","dedup","triangulate","xmin","xmax","ymin","ymax","dmax","xmid","ymid","open","__sentinel","closed","isPointZ","turfBBox","rhumbBearing","rhumbDistance","rhumbDestination","factor","origin","isPoint","defineOrigin","originalDistance","bearing","newDistance","newCoord","originIsPoint","Uint8Array","eq","equalArrays","mapToArray","setToArray","boolTag","dateTag","errorTag","mapTag","numberTag","regexpTag","setTag","stringTag","symbolTag","arrayBufferTag","dataViewTag","symbolProto","symbolValueOf","valueOf","equalByTag","other","bitmask","customizer","equalFunc","byteLength","byteOffset","message","convert","isPartial","size","stacked","hashDelete","has","__data__","lo","hi","getMapData","mapCacheSet","input","constructor","gridToMatrix","zProperty","flags","pointsMatrix","sortPointsByLatLng","matrix","pointRow","matrixPosition","pointsByLatitude","orderedRowsByLatitude","rowOrderedByLongitude","pointMatrix","memoize","MAX_MEMOIZE_SIZE","cache","baseFor","baseForOwn","iteratee","baseEach","baseAggregator","collection","setter","accumulator","mapCacheGet","bits","UnionFind","il","countVertices","vc","jl","cloneCells","ncells","m1","l0","m0","as","bs","compareZipped","normalize","attr","zipped","unique","findCell","incidence","from_cells","to_cells","cl","kn","popCount","idx","dual","vertex_count","skeleton","res","k0","nextCombination","connectedComponents_dense","labels","link","components","component_labels","ranks","connectedComponents_sparse","vj","connectedComponents","nativeCreate","HASH_UNDEFINED","hashSet","baseGetTag","argsTag","baseIsArguments","baseHasIn","toCultivationName","cultivation","frsTranslations","store","cropUsageId","mixtureComponents","toMixtureName","CatchCrop","EcologicalPriorityAreas","TwoCropUsage","InvalidCultivationType","sorted","orderBy","componentsShort","component","percentage","isEcoCompatible","C_src_Solutions_WebApp_node_modules_babel_runtime_corejs2_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__","listCacheClear","position","coordInBBBOX","vertexToCoordinate","hub","rnd","circle_offsets","sumOffsets","scaleOffsets","PI","radial_scaler","objectToString","freeGlobal","freeSelf","self","GeodesyLatLon","LatLonSpherical","distanceInMeters","destination","rhumbDestinationPoint","lineclip","codeB","lastCode","codeA","bitCode","intersect","polygonclip","prevInside","polyline","arrayFilter","predicate","resIndex","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","stackDelete","isFunction","isLength","isArrayLike","convertToMercator","convertToWgs84","lonLat","D2R","MAXEXTENT","adjusted","sign","xy","R2D","atan","exp","shim","stubArray","propertyIsEnumerable","nativeGetSymbols","getOwnPropertySymbols","getSymbols","symbol","toSource","reRegExpChar","reIsHostCtor","funcProto","funcToString","reIsNative","RegExp","pattern","process","useColors","document","documentElement","style","WebkitAppearance","firebug","exception","table","navigator","userAgent","parseInt","$1","formatArgs","args","namespace","humanize","diff","color","lastC","save","namespaces","storage","removeItem","debug","NODE_ENV","BASE_URL","DEBUG","localstorage","localStorage","chrome","local","colors","formatters","enable","calculateToOxidform","calculateFromOxidform","oxideNames","normalFactors","phosphorus","magnesium","potassium","oxideFactors","nutrient","nullTag","undefinedTag","bounds","objects","x0","boundGeometry","boundGeometryType","GeometryCollection","boundPoint","MultiPoint","LineString","boundLine","arcs","MultiLineString","Polygon","MultiPolygon","boundMultiLine","hashset","hash","equal","empty","LN2","mask","collisions","hashmap","keyType","keyEmpty","valueType","keystore","valstore","matchKey","maybeSet","missingValue","point_equal","pointA","pointB","ArrayBuffer","floats","Float64Array","uints","Uint32Array","point_hash","topology","previousIndex","nextIndex","rings","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","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","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","WeakMap","lineOverlap","GeojsonEquality","type1","type2","equality","coords1","coords2","coord1","coord2","segment1","segment2","polygons","pointsWithin","isInside","getMatchData","lineSliceAlong","lineDistance","sliceLineSegments","segmentLength","lineLength","numberOfSegments","outline","addMethods","worker","methods","callbacks","addEventListener","evt","createEvent","initEvent","method","params","dispatchEvent","postMessage","gju","boundingBoxAroundPolyCoords","xAll","yAll","pnpoly","vert","lineStringsIntersect","a1","a2","b1","b2","ua_t","ub_t","u_b","ua","ub","pointInBoundingBox","pointInPolygon","poly","insideBox","insidePoly","pointInMultiPolygon","coords_array","numberToRadius","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","names","tempName","planName","makePartialFieldFeatures","segmentationResults","current","makeParts","makeHeadlandFeatures","parts","makeHeadlandLaneFeatures","seperateMultiLineFeatureToLineFeatures","makeLaneFeatures","isGapLine","makeSelectedCandidateLane","selectedCandidate","isSegment","booleanClockwise","rewind","rewindLineString","rewindPolygon","lineCoords","linear","linear_ab","v0","v1","tmp","linear_a","minV","maxV","linear_b","Options","polygons_full","linearRing","noQuadTree","isoBandOptions","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","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","arraySome","DataView","Map","Set","objectTag","promiseTag","weakMapTag","dataViewCtorString","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","getTag","resolve","Ctor","ctorString","coordsFrom","coordsTo","rhumbDistanceTo","envelopeIsEqual","envelopeContains","coordinatesEqual","multiPoint","envelope","_inside","hiIndex","high","iPrev","iNext","disc","toPolygon","testEdgeRing","shellList","testEnvelope","getEnvelope","minEnvelope","minShell","shell","tryEnvelope","testPoint","createBaseEach","commonParameters","validUnits","convertApplicationValues","makeTemplate","lodash__WEBPACK_IMPORTED_MODULE_0__","productId","unit","zoneMapId","cultivationId","algorithm","applicationValues","wimexMaize","wimexWinterWheat","wimexUnderRootFertilization","mapValues","parameters","estimatedPrecipitation","minSoilMoisture","maxSoilMoisture","additionalZoneValues","dateOfSeed","thousandKernelWeight","germinationCapacity","germination","temperature","ext","tin","dissolve","removeDuplicates","cleaned","existing","maxEdge","tinPolys","pt3","dist1","dist2","dist3","dissolved","hashClear","squareGrid","controlPoints","valueField","weight","cellWidth","filtered","samplingGrid","zw","sw","w","truncate","cultivationToColor","cultivationToName","cultivationTypeToShortcut","src_js_i18n_translate__WEBPACK_IMPORTED_MODULE_0__","_cultivation_planning_helpers__WEBPACK_IMPORTED_MODULE_1__","ecoTypeId","arrayAggregator","baseIteratee","createAggregator","initializer","baseTimes","lowLeft","topLeft","topRight","lowRight","marchingsquares","createIsoLines","breaks","propertiesToAllIsolines","propertiesPerIsoline","isolines","isoline","rescaleIsolines","gridBbox","originalWidth","originalHeigth","matrixWidth","matrixHeight","scaleX","scaleY","resize","pointGrid","scaledIsolines","stackHas","getSqDist","getSqSegDist","simplifyRadialDist","sqTolerance","prevPoint","newPoints","simplifyDPStep","first","last","simplified","maxSqDist","sqDist","simplifyDouglasPeucker","tolerance","highestQuality","earcut","holeIndices","dim","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","holes","dimensions","holeIndex","LatLonEllipsoidal","prop","LatLonVectors","Vector3d","Dms","classificationsPh","soilTypes","ranges","classificationsPKMg","arable","grass","validCalculationSubTypes","isCalculationPossible","soilSubTypeId","soilSubTypeMap","soilSubType","bySoilType","mappedSoilSubType","classification","isWithinRange","computeClassificationPKMg","usage","measurement","_classificationsPKMg$","computeClassificationPh","_classificationsPh$fi","overArg","global","createTopology","mergeTopology","merge","dissolveLineStrings","toArray","dissolvePolygons","geoms","topo","getHomogenousType","flat","multiPolygon","clipPolygon","outRings","clipped","calcBbox","isPointInMultiPoint","isMultiPointInMultiPoint","multiPoint1","multiPoint2","matchFound","isMultiPointOnLine","haveFoundInteriorPoint","isMultiPointInPoly","polyBbox","lineBbox","doBBoxOverlap","midPoint","getMidpoint","poly1Bbox","poly2Bbox","listCacheDelete","listCacheGet","listCacheHas","listCacheSet","ListCache","entries","entry","processPolygon","polygonCoords","ptCoords","eprev","enext","rtan","ltan","nextCoordPair","isLeft","isBelow","isAbove","point1","point2","point3","pointCoords","polyCoords","out","quickselectStep","defaultCompare","sd","newLeft","newRight","swap","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","baseIsMatch","baseMatches","matchData","RADIUS","FLATTENING","POLAR_RADIUS","castPath","baseGet","assocIndexOf","groups","multiMapping","memo","addToGroup","collectedProperties","bboxPolygon","json","arrayProto","lastIndex","cellSize","completelyWithin","xDistance","yDistance","columns","xFraction","yFraction","cellHeight","currentX","column","currentY","cellPoly","xi","yi","poly1","poly2","intersection","isEmpty","baseAssignValue","isArguments","isIndex","isTypedArray","arrayLikeKeys","inherited","isArr","isArg","isBuff","isType","skipIndexes","started","createBaseFor","baseIsTypedArray","baseUnary","nodeUtil","nodeIsTypedArray","arrayTag","funcTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","typedArrayTags","baseToString","heading","midpoint","coordsToLine","affineHull","linearlyIndependent","nhull","frame","arrayMap","hashHas","mapCacheClear","mapCacheDelete","mapCacheHas","MapCache","Stack","equalObjects","baseIsEqualDeep","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","Hash","baseGetAllKeys","keysFunc","symbolsFunc","stackClear","stackGet","stackSet","setCacheAdd","pSlice","objectKeys","actual","expected","opts","Date","getTime","objEquiv","isUndefinedOrNull","copy","range","lengthOrStart","fill","zoneMapHeterogenitySpread","null","None","Homogeneous","SlightlyHeterogeneous","Heterogenous","IncreasinglyHeterogenous","StronglyHeterogenous","spreadByHeterogenity","averageValue","zoneMap","zones","heterogenity","zoneCount","getZoneCount","heterogenityStart","heterogenityStep","zoneFactors","zoneAmounts","pointOnLine","startPt","stopPt","ends","startVertex","stopVertex","clipCoords","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","hasPath","inRing","ignoreBoundary","xj","yj","onBoundary","inBBox","polys","inHole","startDist","stopDist","overshot","interpolated","travelled","xSum","ySum","crossProduct","v2","sub","scalarMult","intersectSegments","qmp","numerator","isParallel","create","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","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","_t","isUserDataCopied","Mt","Dt","At","Ft","Gt","isInteger","getDimension","getCoordinateCopy","qt","Bt","zt","_keys","_values","_itp","objectOnly","Vt","Jt","kt","no","Yt","Ut","Xt","Ht","Wt","jt","Qt","Kt","Zt","$t","te","map_","so","modelType","FLOATING","ne","FIXED","setScale","nameToTypeMap","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","_e","Me","De","_size","Ae","Fe","Ge","childBoundables","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","readNextNode","je","Ke","Ze","tempEnv1","tempEnv2","overlapSeg1","overlapSeg2","Qe","env","Je","$e","tn","segInt","setSegmentIntersector","nn","monoChains","idCounter","nodedSegStrings","nOverlaps","rn","si","sn","msgWithCoord","on","findAllIntersections","isCheckEndSegmentsOnly","li","interiorIntersection","intSegments","intersections","intersectionCount","keepIntersections","un","segStrings","_isValid","ln","toSegmentStrings","hn","mapOp","cn","fn","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","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","counter","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","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","_i","_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","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","_s","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","toLocationSymbol","log10","LOG_10","clamp","append","setCharAt","substr","intValue","isWhitespace","extractSignificantDigits","magnitude","TEN","divide","ONE","multiply","MAX_PRINT_DIGITS","subtract","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_","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","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","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","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","select","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","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","mark","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","plus","minus","dividedBy","angleTo","sinθ","cosθ","rotateAround","axis","theta","qp","geometryCollection","factors","miles","nauticalmiles","degrees","inches","yards","meters","metres","kilometers","kilometres","feet","distanceToDegrees","eachFunc","fromRight","iterable","asyncTag","genTag","proxyTag","lineSegmentStart","lineSegmentEnd","excludeBoundary","ignoreEndVertices","noCustomizer","prevTime","selectColor","createDebug","enabled","curr","coerce","formatter","logFn","bind","skips","disable","centers","controls","stepLength","delay","dz","cacheSteps","mindist","laststep","vector","speed","time","bezier","t2","t3","t1","cultivationData","cultivations","cultivationDataLookup","keyBy","cultivationFeatureLookup","visibleCultivationFeatures","visible","visibleCultivationData","selectedCultivationData","fieldFeatureLookup","selectedFieldFeatures","selectedFieldIds","fieldIds","loadPrerequisiteData","can","permissions","loadCultivations","navigation","sharedCache","deleteCultivation","smarterDelete","acceptAndToggleFilterRule","rule","ruleAccepted","toggleCultivation","removeUnknownSelected","cultivationIds","ids","initializeCultivations","typeShortcut","toggleRule","filterRules","ruleElement","property","setVisibleCultivations","visibleCultivation","clearSelected","clearFilter","deselectFilterType","simplifyJS","cleanCoords","highQuality","simplifyLine","simplifyPolygon","simpleRing","supportsArgumentsClass","supported","unsupported","turfLine","turfPoint","bearingToAngle","convertDistance","distanceToSegment","mercator","distanceAP","euclideanDistance","azimuthAP","azimuthAB","angleA","azimuthBA","azimuthBP","angleB","mercatorPH","toWGS84","euclideanIntersection","distancePH","dab","squareD","Worker","URL","createObjectURL","Blob","freeProcess","types","require","binding","wgs84","ringArea","p3","lowerIndex","middleIndex","upperIndex","coordsLength","rad","defaultValue","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","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","t0","cosRadius","sinRadius","circleRadius","src_circle","circle","rejoin","pointEqual","Intersection","compareIntersection","startInside","subject","clip","rejoin_link","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","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","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","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","SetCache","cacheHas","arrLength","othLength","seen","arrValue","othValue","compared","othIndex","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","potentialPoints","removeEmptyPolygon","polygon1","polygon2","differenced","start0","end0","start1","end1","denom","x4","y4","array1","array2","useSpatialIndex","reportVertexOnVertex","reportVertexOnEdge","filterFn","options0","allEdgesAsRbushTreeItems","ring0","edge0","rbushTreeItem","bboxOverlaps","bboxIsect","ring1","edge1","ifIsectAddToOutput","isBoundaryCase","frac","isOutside","isect","frac0","frac1","getAllKeys","final","calculateFinalBearing","bear","buildMask","maskPolygon","polygonOuters","polygonInners","separatePolygons","outers","inners","featureOuter","featureInner","inner","createMask","world","unionPolygons","createIndex","removed","filterByIndex","separated","masked","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","setRootCropRotations","rotations","cropRotations","addCropRotation","cropRotation","updateCropRotation","cropRotationToUpdate","removeCropRotation","cropRotationId","cropRotationToRemove","setAssignedCropRotationsForOrgUnit","company","assignCropRotationToField","unassignCropRotationFromField","workflows","cultivationsDisplayField","wide","breadcrumbs","actionDisplayField","cultivationPlanning","cultivationPlanningOrgUnit","editCultivationPlanningOrgUnit","alias","cultivationPlan","mixtureManagement","machinesOverview","nutritionStatusForm","personsOverview","companyMixtureManagement","actionDetailsPage","weatherDetails","actionPlanning","fieldSelection","actionPlanningForSingleField","cultivationPlanningFromOrgUnit","actionPlanningForSingleFieldFromList","actionPlanningFromOverview","actionPlanningFromCollection","actionPlanningFromDashboard","lanePlanning","actionOverview","companyData","newCompanyData","companyNumbers","companyAccounts","nutrientRequirement","basicFertilization","samplingOrderCreation","samplingOrderPlanning","probingOrderExport","probingResultManualSettings","probingResultManualValues","probingResultUpload","nutrientMapDisplay","applicationMapCreation","applicationMapPreview","lanePlanSelectionOrgUnit","lanePlanExport","lanePlanDetail","entityImportPreview","defaultYields","simpleApplicationMaps","maizeSowing","mapManagement","mapDetails","applicationMapCreationResult","applicationMapCreationResultMaizeSowing","applicationMapCreationResultSimpleApplicationMaps","applicationMapCreationResultBasicFertilization","applicationMapCreationResultSimon","telemetry","simonModule","applicationDetails","yieldDetails","algorithmicApplicationMapCreation","zoneMapImportSettings","soilMapImportSettings","workflow","setLeftView","view","setRightView","sidebarContent","querySelector","scrollTop","setDataLoading","loadingData","setWorkflow","partialWorkflow","currentWorkflow","setRightSidebarCollapsed","collapsed","rightCollapsed","setLeftSidebarCollapsed","leftCollapsed","updateFieldData","dataByFieldId","newData","updateOrgUnitData","dataByOrgUnitId","orgUnits","setIsNewEntity","isNewEntity","deleteMasterData","addEmptyMasterData","updateCompanyNumber","companyNumber","orgUnitData","removeCompanyNumber","companyNumberId","setEntityStructureEditing","visibility","entityStructureEditing","master_data","master_data_objectSpread","setUserSettings","partialSettings","setUserUiSettings","flag","setFieldTags","tags","setFavoriteState","favorited","favorites","setZoneMapGenerationStatus","gettingZoneMap","updateZoneMapDetails","zoneMapDetails","determineEditingComponent","navigationMutations","cropRotationMutations","layout","entity","masterData","zonemap","setEditingComponent","componentName","editing","setMainPageLoading","mainPageLoading","withLoadingIndicator","action","payload","reloadDefaultFieldData","reloadWeatherData","reloadOrgUnitData","getAndCommit","url","mutation","reloadEntities","forest","newFields","allFields","defaultFieldData","fieldData","reloadSubTreeEntities","subtree","reloadIrrigationSources","reloadSoilTypes","reloadSoilSubTypes","reloadUsageTypes","reloadLegalForms","reloadCompanyForms","reloadMaizeProductData","productSeedRates","rates","preloadStaticData","rootDispatch","loadLotsOfOrgUnitData","skipFocus","fieldsForCurrentOrgUnit","visibleOnly","selectOrgUnit","previousOrgUnitId","nextView","transitions","escape","selectField","previousFieldId","parentLookup","fieldFeature","selectGroup","showCultivationPlan","showActionOverview","showAnnualPlan","showAnnualPlanDiff","showCropRotation","showMachinesOverview","showPersonsOverview","showCompanyNumbers","showCompanyLanePlans","showDefaultYield","post","request","deleteCropRotation","reloadCropRotations","rootOrgUnitId","rootId","rootRotations","reloadAssignedCropRotations","assignedRotations","saveAssignedCropRotations","keyFunction","valueFunction","ProcessFieldWktsWorker","processFieldWkts","wktByFieldId","sent","processFieldWkt","_processFieldWkt","partialFieldData","field_geometries_objectSpread","startEditingField","getCultivationUpdateCandidates","futureCultivations","saveFieldGeometry","_saveFieldGeometry","cultivationUpdates","serverContext","wktsByFieldId","finish","transformToFieldData","loadGeometriesForTag","loadFieldGeometriesForCurrentOrgUnit","_onResult","asyncToGenerator","subtreeInclusive","updateFieldGeometry","_x6","_x7","_updateFieldGeometry","loadBasicFieldData","_loadBasicFieldData","loadFullFieldData","additionalFieldData","createNewOrgUnit","_createNewOrgUnit","parentId","encodeURIComponent","deleteOrgUnit","_deleteOrgUnit","updateOrgUnitName","_x8","_updateOrgUnitName","originalName","createNewField","_x9","_x10","_createNewField","_callee6","_context6","deleteField","_x11","_deleteField","_callee7","_context7","saveCompanyData","_x12","_x13","_saveCompanyData","_callee8","existingCompanyData","_context8","loadMasterData","_x14","_x15","_loadMasterData","_callee9","_context9","_x16","_x17","_updateCompanyNumber","_callee10","_context10","_x18","_x19","_removeCompanyNumber","_callee11","_context11","_x20","_deleteMasterData","_callee12","_context12","saveRestructuredOrgTree","changeList","loadDataForActions","reloadFieldCultivationInfoForOrgUnit","cultivationInfoByFieldId","cultivationInfo","setHarvestYear","previous","setFabCollapsed","fabCollapsed","toggleFavorited","routeLookup","cropUsages","loadUserSettings","loadUserPermissions","setUiFlag","loadWeatherData","promise","centroidCoordinates","getWeatherData","climate","startDate","startOf","endDate","endOf","retrieveWeatherData","parameterNames","validTypes","transformWeatherData","getDateString","year","month","entriesByDay","weatherData","day","entriesByHour","timestamp","dataForHour","parameterIdToName","buildUrl","parametersUrl","parameterNameToId","getClimateData","_getClimateData","monthlyClimateData","displayCultivationsForField","displayActionsForField","entityNameLookup","geoJsonFormat","readFeature","fieldWktsFromOrgUnit","fieldWkts","details","allEntities","filters","entitiesForSelectedOrgUnit","fieldsForSelectedOrgUnit","orgUnitsForSelectedOrgUnit","invertLookup","inverted","allFieldIdsByTag","fieldIdsForSelectedOrgUnitByTag","filteredLookup","fieldIdsForCurrentOrgUnitByTag","existingTags","resolvedView","resolvedBack","back","fieldFeaturesForCurrentOrgUnit","addHistoryEntry","newLocation","history","navigation_objectSpread","field_record_system_navigation","entityForest","text","searching","simplifiedGeometries","entities","flattenEntityForest","subTree","flattenedSubTree","subTreeOrgUnits","subTreeFields","lookupById","setEntityForest","setEntitySubTree","addEntity","removeEntity","renameEntity","selectTag","setSearchText","setSearchResult","setSearching","setSimplifiedGeometries","loadSimplifiedFieldGeometriesForCurrentOrgUnit","geometryLookup","simplifyLowQuality","geojsonGeometry","simplifyHighQuality","config","defaultImportSimplificationTolerance","setEcoTypes","ecoTypes","setCultivationTypes","cultivationTypes","updateCultivation","updateCultivationGeometry","simplifiedGeometry","cloneDeep","setCultivationsForField","setCultivationsForOrgUnit","setPredictedCrop","predictedCrops","clearPredictedCrop","resetPredictedCrops","setMixtures","mixtures","saveCultivation","_saveCultivation","editBuffer","dto","parentOrgUnitId","fieldsForCultivation","idsForField","otherCultivations","org","displayCultivationOverview","launchCultivationPlanning","loadNextCropPredictionForField","reloadCultivationsForOrgUnit","fieldsUnderCultivations","reloadCultivationTypesInternal","reloadCultivationTypes","reloadEcoTypesInternal","reloadEcoTypes","saveQuickCultivation","selectedFieldId","additionalDefaults","harvestYears","dateTimeRange","editCultivationOrgUnit","loadExistingCultivation","initializeNewCultivation","reloadCultivationsForField","editCultivation","editCultivationPlanning","predictNextCrop","reloadMixtures","catchCropMixtures","currentSelectedFieldId","cultivationsForSelectedField","cultivationsByFieldId","fieldIdsByCultivationType","fieldIdsByCropId","subsidies","ecoPriorityArea","expectedYield","expectedYieldUnit","actualYield","edit_buffer","isEcoPriorityArea","edit_buffer_objectSpread","partialCultivation","_defaults","cultivation_planning","setActionsForField","forField","setActionsByField","actionsByField","setActionsForOrgUnit","forOrgUnit","addActionsForOrgUnit","_state$data$actions$f","setActionTemplates","templatesForOrgUnit","setWizardStep","planningWizard","partEditingIndex","productQuantities","setParameterStep","parameterStep","replaceCombination","_state$editBuffer","procedure","combinationParts","addCombinationPart","_state$editBuffer2","setCombinationParts","removeCombinationPart","updateActualAreaForPart","actualArea","action_mutations_objectSpread","setActiveActionId","actionId","setPartEditingIndex","setActionStateForOrgUnit","newState","currentAction","timestamps","setActionStateForField","cultivationsForOrgUnit","setNavigationSource","cancelTarget","saveTarget","navigationSource","wizard_steps","combination","nextFromArray","previousFromArray","parameterSteps","procedureParameterSteps","nextParameterStep","nextStep","wizardSteps","previousParameterStep","validSteps","previousStep","reloadActionData","loadActionsForOrgUnit","loadActionsForCurrentField","loadActionsForFieldForPlanning","startEditingCombinationPart","rest","objectWithoutProperties","startCreatingActionFromField","_startCreatingActionFromField","startEditingActionGeometry","cancelEditing","showActionDetails","saveModifiedActionStatus","stateActions","actionsToUpdate","removeActions","actionIds","loadCultivationsForOrgUnit","groupByField","_ref$details$fieldId","save_action","save_action_ref3","personnel","notes","sharedProperties","actionPartsByFieldId","makeActionWithParts","save_action_objectSpread","planningParts","transformPlanningPartsToCombinationParts","startEditingAction","_startEditingAction","_ref3$navigationSourc","usesExperimentalFinanceIntegration","restOfAction","editingViewMapping","editingView","auditInfo","mainCultivation","edit_action_objectSpread","activeAction","fieldCultivationFeaturePairs","relevantCultivationsByFieldId","cultivationFeature","clippedCultivationFeatures","featurePairs","geometry_getters_objectSpread","_unused","cutOffCultivationFeatures","flatFeaturePairs","groupedPairs","pair","fieldFeatures","pickBy","combinedCultivationFeatures","remainingFieldFeatures","combinedCultivationGeometry","bufferedFeature","finalActionFeatures","customGeometries","customGeometry","availableCultivations","selectedCultivations","selectedCultivationIdsByFieldId","allCultivationsSelected","remainingFieldSelected","cultivationFeatures","selectedCultivationIds","filteredFeatures","finalActionTotalArea","areaFeatures","selectionSummaryByFieldId","selectedCultivationCount","availableCultivationCount","atLeastOneCultivationSelected","hasRemainingField","hasCustomGeometry","somethingSelected","everythingSelected","withTime","planned","resetDetails","detailsLookup","procedureParameterDefaults","currentParameters","setType","procedures","action_edit_buffer","action_edit_buffer_objectSpread","geometryGetters","selectionGetters","hasStarted","completed","isPlanned","isCompleted","forIn","cultivationDateValidityLookup","_state$timestamps$pla","fromPairs","_cultivation$dateTime","cultivationStart","cultivationEnd","_map","_map2","partialReset","toggleFieldId","relevantCultivationIds","setCustomGeometry","toggleCultivationId","setPlannedStart","isoDate","setPlannedEnd","setActualStart","setActualEnd","setProcedure","setMachineIds","setPersonnelIds","partialAction","defaultAction","isFieldLevel","toggleAll","_getters$selectionSum","isSelected","actionHierarchy","cultivationsByField","field_record_system_action","action_objectSpread","saveAction","loadMachineGroups","machineGroups","sortBy","loadMachines","saveMachine","removeMachine","shareMachineToChilds","startEditing","group","stopEditing","setMachines","setEditing","setMachineGroups","deleteMachine","vin","isRetracted","isArchived","partialMachine","defaultMachine","machines_edit_buffer","machines_edit_buffer_objectSpread","field_record_system_machines","loadPersons","savePerson","person","removePerson","sharePersonsToChilds","setPersons","persons","personId","partialPerson","defaultPerson","editBuffer_objectSpread","ensureUniqueIds","helpers_objectSpread","assertGeoJson","historyMove","activeFeatures","guides","guideFeatures","replacement","map_mutations_objectSpread","updateFabPosition","fab","getCenter","getExtent","setGlobalAutoFit","autoFit","setFocusExtent","focusExtent","addVectorLayer","layers","layerList","removeVectorLayer","setFeatures","writeFeatureObject","setActiveFeatures","setGuideFeatures","pushVectorStyle","styleStack","popVectorStyle","setVectorStyle","setSelectedIds","selectedIds","setStyle","setBingVisible","bing","defaultInteractionsEnabled","setMode","setOriginalStyles","stylesDict","originalStyles","copyToClipboard","clipboard","pasteAsPolygons","layerId","polyLikeFilter","_state$editing$guideF","_state$editing$active","recordFeatures","redoBuffer","undoBuffer","noRedo","redo","clearEditingHistory","moveLayerUp","moveLayerDown","actions_focus","wktFormat","readGeometry","dataProjection","featureProjection","readFeatures","combined","createEmpty","setupEditing","dissolveMultiGeometries","setupExpertMode","selectSensibleDefaults","startQuickMode","switchToExpertMode","flavor","startExpertMode","_stopEditing","deleteSelection","unselected","simplifyGeometry","selectedFeatures","otherFeatures","borderRecognition","_ref11$coordinate","featureLoadingFunction","recognizedBorder","currentFeatures","field_record_system_map","showDefaultLayers","abortEditing","sharedPlugins","validateWhileChange","snapping","roads","showImportSimplificationHint","showGeometryErrors","map_objectSpread","setBorderRecognitionStatus","mainCropId","mainCropNitrogenRequirement","mainCropIncrease","mainCropDecrease","mainCropDifference","previousCropId","catchCropId","averageYieldLast3Years","yieldDifference","nitrogenActual","nitrogenHumusContentIsLow","additionalRequirementFromCover","nitrogenFertilizationPreviousYear","nitrogenFertilizationForCalculation","nitrogenRequirement","phosphorusPlans","pDefaults","corrections","currentCorrection","supplementsAndDiscountsForYieldDifference","previousCrop","catchCrop","valueFromPreviousOrCatchCrop","typeOfSoil","cropPhosphorusRequirement","mainToByproductRatio","phosphorusContentByproduct","totalPRevocation","byproductIsRemoved","phosphorusContentClass","phosphorusRequirement","harvestCrop","cropResidues","defaultCorrection","amount","note","recalculatePhosphorusValues","supplementsAndDiscountsCalculation","humusNAmount","nRequirementTemp","harvestCropTemp","cropResiduesTemp","pRequirementTemp","nutrient_requirement_edit_buffer_objectSpread","setSupplementsAndDiscountsForYieldDifference","setAverageYieldLast3Years","setNitrogenFertilizationPreviousYear","setNHumusContentIsLow","setNitrogenActual","setAdditionalRequirementFromCover","setMainCropDetails","mainCrop","increase","decrease","setPreviousCrop","setCatchCrop","partialNutrientRequirement","defaultNutrientRequirement","setPartialPPlan","partialPhosphorusPlan","addYear","removeYear","updateYear","addCorrection","updatePhosphorusContent","tempPlan","nutrient_requirement_edit_buffer","setNutrientRequirementsForField","nutrientRequirements","setCorrections","nutrientRequirementId","correction","correctionsTemp","correctionTemp","setCrops","crops","setCatchCrops","catchCrops","setPreviousCrops","previousCrops","addPRequirement","editCorrection","setStep","wizardStep","getNutrientRequirement","_getNutrientRequirement","fieldInfo","soilType","soil","loadCrops","transformedCrops","crop","KULTURNAME","ERTRAGSNIVEAU","STICKSTOFFBEDARFSWERT","P2O5_ENTZUEGE","DIFFERENZ","ZUSCHLAEGE","ABSCHLAEGE","ERNTERESTE_P2O5","HNV","loadPreviousCrops","VORFRUCHT","minimumReduction","MINDESTABSCHLAG_KG_N_HA","loadCatchCrops","getNutrientRequirementId","saveCorrection","nutrient_requirement_actions_objectSpread","deleteCorrection","reloadCorrections","saveRequirements","_saveRequirements","lastCropId","wizard_actions","cancel","harvestActions","nutrient_requirement","nutrient_requirement_objectSpread","wizardActions","setNutrientMaps","nutrientMaps","initializeOrder","probingSites","order","created","generateGeometry","wkt1","wkt2","sortedProbingSites","isActive","orderCreation","sampleId","useCustomIds","updateOrderName","updateZoneMaps","zoneMaps","zoneMapIdsByFieldId","basic_fertilization_mutations_objectSpread","updateDefaultYields","applicationMaps","creation","defaultYieldsByFieldId","startBasicFertilization","navigateToStartPage","_navigateToStartPage","loadStatistics","createNewOrder","probingSite","saveOrder","exportOrders","orders","startNutrientMapDisplay","order_creation","order_creation_objectSpread","setOrderName","startOrderCreation","continueToNextStep","getFlattenedProbingSites","probingSitesByFieldId","order_planning_actions_objectSpread","startOrderPlanning","_startOrderPlanning","orderId","cancelOrderPlanning","_saveOrder","selectedOrder","deletedIds","existingProbingSites","added","updated","deleted","planningProbingSites","addedIds","samplingOrderGeometries","uniq","uniqBy","fieldNames","selectedOrderId","hard","selectedZoneMapId","new","probingSiteMode","setShowNumbers","showNumbers","setProbingSitesByFieldId","finishField","order_planning_mutations_objectSpread","setIncompleteOrders","incompleteOrders","setSelectedOrderId","setSelectedFieldId","addNewProbingSite","nextLabel","renameProbingSite","toggleActive","convertProbingSite","setActiveForAll","geometryType","startsWith","toggleDeletion","setSelectedZoneMapId","setProbingSiteMode","resetChanges","getUndeletedProbingSitesAsArray","probingSitesObject","filterDeleted","order_planning","safeProbingSitesByFieldId","storedProbingSites","activeProbingSitesByFieldId","activeCountByFieldId","duplicateLabelsByFieldId","grouped","allFieldsPlanned","duplicateLabelsFound","duplicates","csv","header","_parse$coordinates","longitude","latitude","body","order_export","openOrders","optionalSampleIdKey","optionalFieldNameKey","order_export_objectSpread","downloadAsShape","processProbingGeometry","filledCoordinates","previousCoordinate","_proj","proj4","_proj2","_proj3","_proj4","num","getCoordinateAt","uploadDefaults","shapeFileFeatures","columnMapping","order_import","upload","allSampleIdsAreValid","sampleIdPropertyExists","getKeys","hasMultiPointGeometries","validSampleIdColumn","shapeFileColumns","getProperties","order_import_objectSpread","importOrder","samplingOrderId","lab_presets","phosphorusValue","phosphorusClassification","phosphorusIsOxide","magnesiumValue","magnesiumClassification","magnesiumIsOxide","potassiumValue","potassiumClassification","potassiumIsOxide","phValue","phClassification","limeRecommendation","SoilSubType","stringToUpperCase","result_import","manual","nutrients","probingMethod","selectedSamplingOrderGeometryId","fileContents","semicolonSeparated","useLabPreset","labPresets","lab","lastCalculationSoilSubTypeLookup","ignoreClassification","newResults","samplingOrderGeometryId","hasNewData","savedResultsLookup","newResultsValidity","nutrientValues","nutrientValid","savedResult","validityByNutrient","newResultsCombinedValidity","validNewResults","csvSeparator","csvLinesRaw","csvLines","processLine","csvHeaders","csvData","parsedCsvData","transformRow","validRows","sampleIdColumn","sampleIdsAreUnique","mappingComplete","nutrientIsMapped","result_import_objectSpread","canCalculateContentClasses","savedResults","resetManualSettings","generateResultsForOrder","resultLookup","assignResults","analyzeFile","updateResult","partialResult","updateColumnMapping","setUseLabPreset","toggleSelectedFieldId","setLab","setIgnoreClassification","calculateClassifications","allResults","fieldInfoByGeometry","calculateContentClasses","geometryId","geometryIds","updatedSoilSubTypes","setIsOxide","getOpenOrders","startManualEntry","startImportWizard","finalizeImportSettings","parseMeasurement","isOxide","csvIdsContainedInOrder","uniqueIdsInCsv","findPoint","sampleIdIsEnough","soilSubTypes","csvResults","aliases","soilGroup","potassiumContentClass","magnesiumContentClass","phContentClass","phosphorusMeasurement","potassiumMeasurement","magnesiumMeasurement","phMeasurement","finalizeManualSettings","saveResults","forceComplete","completeUrl","metrics","createNutritionMap","createYoutrackIssue","formData","headers","Content-Type","nutrient_maps","selectedNutrient","showClassifications","showZentroid","nutrient_maps_objectSpread","loadNutrientMaps","nutrientMapIds","nutrientMap","mapIdsByFieldId","mapId","startApplicationMapCreation","navigateToStart","startYieldPlanning","adjustHeterogenity","createApplicationMap","application_maps_actions_createApplicationMap","_state$creationParame","otherParameters","selectedNutrients","creationParameters","application_maps_actions_objectSpread","minMaxValuesByNutrient","zoneMapIdByFieldId","plannedYieldDefaults","cropHarvestQualityId","averageYield","useByProduct","zoneYields","zoneWithdrawals","initializeYieldPlanningData","years","plannedYields","removePlannedYields","addPlannedYields","setPlannedYieldData","plannedYield","resetYieldPlanning","calculateYieldData","cropHarvestQualities","firstLetterBig","heterogenityFactors","completedPlannedYields","quality","calculateAdjustedYield","mainProductFactor","byProductFactor","withdrawalFactor","creationParameterDefaults","ph","desiredZones","application_maps","isApplicationValue","lastInitializedZoneMapId","mapLookup","mapsToCreate","onlyPhSelected","phAndNutrientsSelected","mapType","onlyNutrientsSelected","application_maps_objectSpread","flowActions","applicationMapActions","setYears","oldYears","initializeHeterogenity","calculateYieldDataForField","saveHeterogenityFactors","plannedYieldMutations","setZoneMapId","startCreation","resetAfterCreation","safeDivideBy","nutrientType","applicationMap","selectedProduct","products","product","productFactor","originalRawValues","originalProductValues","divideByProductFactor","adjustedRawValues","averageAdjustment","previousFertilization","_state$ui$application","metaData","orderParameters","adjustedProductValues","manuallyAdjustedZoneValues","manuallyAdjustedValues","startApplicationMapPreview","_startApplicationMapPreview","loadApplicationMapsPreview","_loadApplicationMapsPreview","maps","adjustZoneValueManually","zoneId","rawValue","loadApplicationMap","applicationMapId","geographicArea","setPreviousFertilization","deleteSelectedMap","saveApplicationMap","application_maps_preview_actions_objectSpread","removeSelectedMap","setApplicationMapsForPreview","resetFieldId","resetUi","postProcessingUiParameterDefaults","removeMapFromArray","removeMapFromLookup","applicationMapIdsByFieldId","resetInputs","postProcessingParameterDefaults","application_maps_preview","application_maps_preview_objectSpread","fieldStatisticsLookup","testing","contentClassResults","basic_fertilization","basic_fertilization_objectSpread","orderPlanning","orderExport","orderImport","resultImport","applicationMapsPreview","fieldDetails","field_details_actions_save","rootCommit","clientContext","field_details_actions_objectSpread","splitField","_splitField","_rootState$fieldRecor","router","setFields","upsertField","fieldUsage","official","cultivated","geometrical","waterProtectionZone","natura2000","waterErosion","windErosion","partialfield","defaultField","field_details_editBuffer","field_details_editBuffer_objectSpread","mappedField","saving","selectedClimateCategory","climateCategories","evapotranspiration","climaticWaterBalance","heatSummation","precipitation","wind","cloudCover","field_details","field_details_objectSpread","hasCompanyData","shouldHaveCompanyData","saveCompany","_saveCompany","currentOrgUnitId","clonedEditBuffer","promises","setCompanies","companies","upsertCompany","address1","address2","address3","isOperatedEcologically","isSupplementarySourceOfIncome","companyForm","legalForm","invekos","email","phoneNumber","partialCompany","defaultCompany","company_data_editBuffer","company_data_editBuffer_objectSpread","nextPaymentData","paymentDataMZK","missingPaymentData","getMissingCompanyData","missingPaymentDataMZK","paymentData","requiredData","missingData","_requiredData","propName","company_data","defaultMeasurements","nitrogen","layer30","layer60","layer90","humusContent","waterLevel","calculateTotalNitrogenValue","nitrogenLayerValues","measurements","total","setUniformTimestamp","nutrition_status","useUniformTimestamp","anyNutrientHasValue","uniformTimestamp","nutrition_status_objectSpread","setLayer30","setLayer60","setLayer90","setUseUniformTimestamp","partialNutritionStatus","_save","measurementLookup","otherNutrients","simple_application_maps","byHeterogenity","averageAmount","reverseZoneAmounts","cropUsage","cropId","hasCropTagForSimpleApplicationMaps","shortcut","simple_application_maps_objectSpread","setProductId","startSimpleApplicationMaps","addUnitsAndGetCropusageByCultivationId","_addUnitsAndGetCropusageByCultivationId","viewResultPage","automaticSupported","productData","maizeMatrix","field_record_system_maize_sowing","soilQuality","automatic","ignoreLimits","customSowingDensity","limits","_getters$productData","minSeedRate","maxSeedRate","sowingDensity","_state$parameters","calculatedZoneAmounts","amounts","maize_sowing_objectSpread","startMaizeSowing","_createApplicationMap","soilDetail","usableFieldCapacity","saveSoilData","_saveSoilData","oldSoil","soil_detail_actions_objectSpread","partialSoilDetail","defaultSoilDetail","soil_detail_editBuffer","soil_detail_editBuffer_objectSpread","setSoilQuality","setSoilType","setSoilSubType","setUsableFieldCapacity","soil_detail","convert_to_tree","newOrg","parentName","newField","getOrCreateOrg","orgName","subOrgName","entity_import","colorProperty","convertToTree","selectedTree","prune","entity_import_objectSpread","entityImportTree","convertNode","template","parents","epsgCodes","customEpsgCodes","simplifyAndSetGeojson","addCustomEpsgCode","toggleNode","toggleSingleNode","toggle","startImportPreview","startImport","default_yields","yield","selectedEntityId","default_yields_objectSpread","startEditingDefaultYields","loadDefaultYields","applicationMapsDataDefaults","applicationMapCalculated","applicationMapCreationFailed","field_record_system_application_maps","page","algorithmCollection","field_record_system_application_maps_objectSpread","setAlgorithm","algorithmObject","algorithmGroup","cleanedParameters","pick","algorithmTemplate","showPreview","algorithmOutput","algorithmParameters","discardPreview","setApplicationMapCalculated","ready","failed","resetCreationStatus","setApplicationMapId","_startCreation","loadAdditionalZoneValues","productAlgorithms","zoneValues","zoneData","_arr","runAlgorithm","pwc","acresRatio","acreRatio","waterAvailability","currentTemperature","objectReducer","byNumber","cancelCreation","createApplicationMapSuccess","_createApplicationMapSuccess","previewsApplicationMapId","convert_to_legacy_payload","compatPayload","fieldIdsByMapId","selectedConverter","selectedUnit","description","includeFieldBorder","multipleFiles","multipleMapTypesWithMaizeSowing","fieldIdsByMapIdClone","geodata","converter","selectedUnitShortcut","getKmlColors","_getKmlColors","applicationMapPalette","zoneMapPalette","colorPaletteByMap","requests","palette","zoneDetailsUrl","category","mapToColors","toHexAbgr","convertersByMapType","biomassMap","fieldBorder","soilMap","sensorData","validShapeConvertersForMultiDownload","converterWithIncludeFieldBorderOption","field_record_system_download","selectedMapIds","showConverterModal","srcUnit","validConverters","selectedMaps","everySelectedMapIsSensorData","element","workaroundMapType","download_objectSpread","startDownload","resetAppMapProps","mapsInfos","unitType","unitShortcut","hasSameUnitType","hasSameMapType","unitShortcuts","hasSameUnitShortcut","maizeSowingInfos","_download","urls","categories","hasSameCategory","_url","_data","useFieldBorder","sensorRaster","mapIds","convertToLegacyPayload","telemetry_mutations","telemetry_mutations_objectSpread","setMetaDataAll","applications","applicationMetaData","productions","productionMetaData","applicationMapData","metaDataAll","deleteTelemetry","selectedMetaData","telemetry_actions","showTelemetryOverview","getMeasurements","isApplication","data_import_actions","importYieldData","valueKey","timestampKey","metadata","data_import_mutations","data_import_mutations_objectSpread","typeOptions","data_import","dataImport","fertilizationDefaults","minValue","maxValue","selectedYieldMapId","yieldMetaData","yieldData","applicationData","numberZones","numberYears","maxApplicationValue","mapName","selectedMapId","pFactor","simon_module_mutations","simon_module_mutations_objectSpread","setApplicationMinValue","setApplicationMaxValue","setApplicationDetails","newGuid","setApplicationName","setApplicationNumber","resetApplicationData","setApplicationData","setApplicationMetaData","setYieldName","resetYieldDetails","updateYieldDataList","removeYieldCard","fertilizationDataId","removeProductionCard","applicationDataId","simon_module_actions","saveYieldDetails","selectedMap","saveProductionDetails","startSimonModule","startComputation","startAddApplicationMap","goBackToSimon","simon_module","migration","migration_objectSpread","loadMigratedFields","actionPlanningFromDiff","actionDetails","waitscreen","geometryEditing","usageTypes","companyForms","legalForms","waterExtractionSources","cultivationOverview","nutritionStatus","entityImport","measureDistance","getRandomSubarray","shuffled","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","objProps","objLength","othProps","skipCtor","objCtor","othCtor","MAX_SAFE_INTEGER","lineSegment","numeA","numeB","uA","uB","Coord","antipode","anti_lat","anti_lon","move_to","Arc","multiline","wkt_string","collect","GreatCircle","npoints","first_pass","bHasBigDiff","dfMaxSmallDiffLong","dfDateLineOffset","dfLeftBorderX","dfRightBorderX","dfDiffSpace","dfPrevX","dfX","dfDiffLong","poMulti","poNewLS","dfX0","dfX1","dfY1","dfX2","dfY2","tmpX","tmpY","dfRatio","dfY","poNewLS0","j0","identity","feat","isNumber","centimeters","centimetres","areaFactors","millimeter","acres","multiplier","originalUnit","finalUnit","convertedDistance","convertArea","startFactor","finalFactor","convertAngleTo360","alfa","beta","bearing1","bearing2","angle1","angle2","arcStartDegree","arcEndDegree","hashGet","outField","SPLITTER","abig","ahi","alo","bbig","bhi","blo","err1","err2","err3","reIsUint","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","addOuterEdge","addInnerEdge","removeOuterEdge","removeInnerEdge","seeding","broad","plantsPerSqm","emergence","coating","thousandSeedWeight","seedsPerSqm","rowSeparation","rowDistance","drill","single","totalPlants","packageSize","plant","stripTill","cornCloseSeed","mulch","tillage","schlegeln","plowing","grubbern","eggen","basic","stoppelsturz","seedbed","walzen","scheibeneggen","fraesen","kreiseleggen","protection","hacken","harrow","spray","bbch","maintenance","mulchenSchlaegeln","schleppen","vertikutieren","irrigation","pipe","waterAmount","waterExtraction","circular","drum","jet","drip","underground","mobile","transport","cargoType","internal","harvest","maehdrusch","mainCropYield","catchCropYield","actualQuality","moisture","dryMatter","protein","sugar","correctedSugar","starch","sedimentation","adhesiveProtein","lipid","fiber","ash","brokenGrains","fallingNumber","impurity","wetAdhesiveProtein","mycotoxins","gruenlandSchnitt","cutNumber","cuttingTime","grassYield","roden","schneiden","buendeln","haeckseln","pressen","pfluecken","stechen","wenden","schwaden","silieren","fertilization","mineral","fertilizerData","density","fertilizerNutrientContents","sulphur","nitrate","ammonium","nitrogenAmide","isLiquid","applicationMethod","useCustomProduct","customProductName","organic","getSettings","settingsOrAlias","createContourLines","contours","lowerBand","upperBand","isobandsCoords","nestedRings","orderByArea","groupedRings","groupNestedRings","rescaleContours","contour","lineRingSet","lineRing","ringsCoords","ringsWithArea","orderedByArea","orderedLinearRings","lrList","lrCoordinates","groupedLinearRingsCoords","allGrouped","outerMostPoly","lrPoly","testPolygon","targetPolygon","commonProperties","isobandProperties","multipolygons","contourProperties","multiP","monotoneConvexHull2D","lower","upper","nl","convexHullnD","ich","aff","permute","front","invPermute","ah","isSymbol","INFINITY","symbolToString","booleanPointOnLine","concatSegment","overlapSegment","doesOverlaps","coordsSegment","coordsMatch","LARGE_ARRAY_SIZE","pairs","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","λm","Δλi","λi1","λi2","Δψ","rhumbBearingTo","rhumbMidpointTo","f1","f2","f3","isPoleEnclosedBy","ΣΔ","prevBrng","initBrng","finalBrng","bear360","coordsStart","coordsEnd","bear180","setCacheHas","splitLineWithPoints","splitter","closestLine","findClosestFeature","splitLineWithPoint","pointsEquals","closestSegment","lastCoords","splitterCoords","closestFeature","splitterType","truncatedSplitter","dx1","dy1","envX1","envY1","envX2","envY2","roots","makeSet","xd","yd","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","ij","ik","untransform","quantize","box","quantizeArc","generator","hasFunc","FUNC_ERROR_TEXT","resolver","memoized","Cache","basePropertyDeep","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","baseProperty","cloneFeature","cloned","cloneProperties","cloneGeometry","cloneFeatureCollection","deepSlice","convex","centerOfMass","pj","translation","sArea","neutralizedPoints","areaFactor","reIsDeepProp","reIsPlainProp","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","pivot","initialAngle","finalAngle","lineOffset","offsetDegrees","finalCoords","processSegment","seg2Coords","out1x","out2x","out1y","out2y"],"mappings":"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","file":"js/chunk-1b0a0495.eb5cb209.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 Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\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","'use strict';\n\nmodule.exports = rbush;\nmodule.exports.default = rbush;\n\nvar quickselect = require('quickselect');\n\nfunction rbush(maxEntries, format) {\n if (!(this instanceof rbush)) return new rbush(maxEntries, format);\n\n // max entries in a node is 9 by default; min node fill is 40% for best performance\n this._maxEntries = Math.max(4, maxEntries || 9);\n this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));\n\n if (format) {\n this._initFormat(format);\n }\n\n this.clear();\n}\n\nrbush.prototype = {\n\n all: function () {\n return this._all(this.data, []);\n },\n\n search: function (bbox) {\n\n var node = this.data,\n result = [],\n toBBox = this.toBBox;\n\n if (!intersects(bbox, node)) return result;\n\n var nodesToSearch = [],\n i, len, child, childBBox;\n\n while (node) {\n for (i = 0, len = node.children.length; i < len; i++) {\n\n child = node.children[i];\n childBBox = node.leaf ? toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf) result.push(child);\n else if (contains(bbox, childBBox)) this._all(child, result);\n else nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return result;\n },\n\n collides: function (bbox) {\n\n var node = this.data,\n toBBox = this.toBBox;\n\n if (!intersects(bbox, node)) return false;\n\n var nodesToSearch = [],\n i, len, child, childBBox;\n\n while (node) {\n for (i = 0, len = node.children.length; i < len; i++) {\n\n child = node.children[i];\n childBBox = node.leaf ? toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf || contains(bbox, childBBox)) return true;\n nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return false;\n },\n\n load: function (data) {\n if (!(data && data.length)) return this;\n\n if (data.length < this._minEntries) {\n for (var i = 0, len = data.length; i < len; i++) {\n this.insert(data[i]);\n }\n return this;\n }\n\n // recursively build the tree with the given data from scratch using OMT algorithm\n var node = this._build(data.slice(), 0, data.length - 1, 0);\n\n if (!this.data.children.length) {\n // save as is if tree is empty\n this.data = node;\n\n } else if (this.data.height === node.height) {\n // split root if trees have the same height\n this._splitRoot(this.data, node);\n\n } else {\n if (this.data.height < node.height) {\n // swap trees if inserted one is bigger\n var tmpNode = this.data;\n this.data = node;\n node = tmpNode;\n }\n\n // insert the small tree into the large tree at appropriate level\n this._insert(node, this.data.height - node.height - 1, true);\n }\n\n return this;\n },\n\n insert: function (item) {\n if (item) this._insert(item, this.data.height - 1);\n return this;\n },\n\n clear: function () {\n this.data = createNode([]);\n return this;\n },\n\n remove: function (item, equalsFn) {\n if (!item) return this;\n\n var node = this.data,\n bbox = this.toBBox(item),\n path = [],\n indexes = [],\n i, parent, index, goingUp;\n\n // depth-first iterative tree traversal\n while (node || path.length) {\n\n if (!node) { // go up\n node = path.pop();\n parent = path[path.length - 1];\n i = indexes.pop();\n goingUp = true;\n }\n\n if (node.leaf) { // check current node\n index = findItem(item, node.children, equalsFn);\n\n if (index !== -1) {\n // item found, remove the item and condense tree upwards\n node.children.splice(index, 1);\n path.push(node);\n this._condense(path);\n return this;\n }\n }\n\n if (!goingUp && !node.leaf && contains(node, bbox)) { // go down\n path.push(node);\n indexes.push(i);\n i = 0;\n parent = node;\n node = node.children[0];\n\n } else if (parent) { // go right\n i++;\n node = parent.children[i];\n goingUp = false;\n\n } else node = null; // nothing found\n }\n\n return this;\n },\n\n toBBox: function (item) { return item; },\n\n compareMinX: compareNodeMinX,\n compareMinY: compareNodeMinY,\n\n toJSON: function () { return this.data; },\n\n fromJSON: function (data) {\n this.data = data;\n return this;\n },\n\n _all: function (node, result) {\n var nodesToSearch = [];\n while (node) {\n if (node.leaf) result.push.apply(result, node.children);\n else nodesToSearch.push.apply(nodesToSearch, node.children);\n\n node = nodesToSearch.pop();\n }\n return result;\n },\n\n _build: function (items, left, right, height) {\n\n var N = right - left + 1,\n M = this._maxEntries,\n node;\n\n if (N <= M) {\n // reached leaf level; return leaf\n node = createNode(items.slice(left, right + 1));\n calcBBox(node, this.toBBox);\n return node;\n }\n\n if (!height) {\n // target height of the bulk-loaded tree\n height = Math.ceil(Math.log(N) / Math.log(M));\n\n // target number of root entries to maximize storage utilization\n M = Math.ceil(N / Math.pow(M, height - 1));\n }\n\n node = createNode([]);\n node.leaf = false;\n node.height = height;\n\n // split the items into M mostly square tiles\n\n var N2 = Math.ceil(N / M),\n N1 = N2 * Math.ceil(Math.sqrt(M)),\n i, j, right2, right3;\n\n multiSelect(items, left, right, N1, this.compareMinX);\n\n for (i = left; i <= right; i += N1) {\n\n right2 = Math.min(i + N1 - 1, right);\n\n multiSelect(items, i, right2, N2, this.compareMinY);\n\n for (j = i; j <= right2; j += N2) {\n\n right3 = Math.min(j + N2 - 1, right2);\n\n // pack each entry recursively\n node.children.push(this._build(items, j, right3, height - 1));\n }\n }\n\n calcBBox(node, this.toBBox);\n\n return node;\n },\n\n _chooseSubtree: function (bbox, node, level, path) {\n\n var i, len, child, targetNode, area, enlargement, minArea, minEnlargement;\n\n while (true) {\n path.push(node);\n\n if (node.leaf || path.length - 1 === level) break;\n\n minArea = minEnlargement = Infinity;\n\n for (i = 0, len = node.children.length; i < len; i++) {\n child = node.children[i];\n area = bboxArea(child);\n enlargement = enlargedArea(bbox, child) - area;\n\n // choose entry with the least area enlargement\n if (enlargement < minEnlargement) {\n minEnlargement = enlargement;\n minArea = area < minArea ? area : minArea;\n targetNode = child;\n\n } else if (enlargement === minEnlargement) {\n // otherwise choose one with the smallest area\n if (area < minArea) {\n minArea = area;\n targetNode = child;\n }\n }\n }\n\n node = targetNode || node.children[0];\n }\n\n return node;\n },\n\n _insert: function (item, level, isNode) {\n\n var toBBox = this.toBBox,\n bbox = isNode ? item : toBBox(item),\n insertPath = [];\n\n // find the best node for accommodating the item, saving all nodes along the path too\n var node = this._chooseSubtree(bbox, this.data, level, insertPath);\n\n // put the item into the node\n node.children.push(item);\n extend(node, bbox);\n\n // split on node overflow; propagate upwards if necessary\n while (level >= 0) {\n if (insertPath[level].children.length > this._maxEntries) {\n this._split(insertPath, level);\n level--;\n } else break;\n }\n\n // adjust bboxes along the insertion path\n this._adjustParentBBoxes(bbox, insertPath, level);\n },\n\n // split overflowed node into two\n _split: function (insertPath, level) {\n\n var node = insertPath[level],\n M = node.children.length,\n m = this._minEntries;\n\n this._chooseSplitAxis(node, m, M);\n\n var splitIndex = this._chooseSplitIndex(node, m, M);\n\n var newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));\n newNode.height = node.height;\n newNode.leaf = node.leaf;\n\n calcBBox(node, this.toBBox);\n calcBBox(newNode, this.toBBox);\n\n if (level) insertPath[level - 1].children.push(newNode);\n else this._splitRoot(node, newNode);\n },\n\n _splitRoot: function (node, newNode) {\n // split root node\n this.data = createNode([node, newNode]);\n this.data.height = node.height + 1;\n this.data.leaf = false;\n calcBBox(this.data, this.toBBox);\n },\n\n _chooseSplitIndex: function (node, m, M) {\n\n var i, bbox1, bbox2, overlap, area, minOverlap, minArea, index;\n\n minOverlap = minArea = Infinity;\n\n for (i = m; i <= M - m; i++) {\n bbox1 = distBBox(node, 0, i, this.toBBox);\n bbox2 = distBBox(node, i, M, this.toBBox);\n\n overlap = intersectionArea(bbox1, bbox2);\n area = bboxArea(bbox1) + bboxArea(bbox2);\n\n // choose distribution with minimum overlap\n if (overlap < minOverlap) {\n minOverlap = overlap;\n index = i;\n\n minArea = area < minArea ? area : minArea;\n\n } else if (overlap === minOverlap) {\n // otherwise choose distribution with minimum area\n if (area < minArea) {\n minArea = area;\n index = i;\n }\n }\n }\n\n return index;\n },\n\n // sorts node children by the best axis for split\n _chooseSplitAxis: function (node, m, M) {\n\n var compareMinX = node.leaf ? this.compareMinX : compareNodeMinX,\n compareMinY = node.leaf ? this.compareMinY : compareNodeMinY,\n xMargin = this._allDistMargin(node, m, M, compareMinX),\n yMargin = this._allDistMargin(node, m, M, compareMinY);\n\n // if total distributions margin value is minimal for x, sort by minX,\n // otherwise it's already sorted by minY\n if (xMargin < yMargin) node.children.sort(compareMinX);\n },\n\n // total margin of all possible split distributions where each node is at least m full\n _allDistMargin: function (node, m, M, compare) {\n\n node.children.sort(compare);\n\n var toBBox = this.toBBox,\n leftBBox = distBBox(node, 0, m, toBBox),\n rightBBox = distBBox(node, M - m, M, toBBox),\n margin = bboxMargin(leftBBox) + bboxMargin(rightBBox),\n i, child;\n\n for (i = m; i < M - m; i++) {\n child = node.children[i];\n extend(leftBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(leftBBox);\n }\n\n for (i = M - m - 1; i >= m; i--) {\n child = node.children[i];\n extend(rightBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(rightBBox);\n }\n\n return margin;\n },\n\n _adjustParentBBoxes: function (bbox, path, level) {\n // adjust bboxes along the given tree path\n for (var i = level; i >= 0; i--) {\n extend(path[i], bbox);\n }\n },\n\n _condense: function (path) {\n // go through the path, removing empty nodes and updating bboxes\n for (var i = path.length - 1, siblings; i >= 0; i--) {\n if (path[i].children.length === 0) {\n if (i > 0) {\n siblings = path[i - 1].children;\n siblings.splice(siblings.indexOf(path[i]), 1);\n\n } else this.clear();\n\n } else calcBBox(path[i], this.toBBox);\n }\n },\n\n _initFormat: function (format) {\n // data format (minX, minY, maxX, maxY accessors)\n\n // uses eval-type function compilation instead of just accepting a toBBox function\n // because the algorithms are very sensitive to sorting functions performance,\n // so they should be dead simple and without inner calls\n\n var compareArr = ['return a', ' - b', ';'];\n\n this.compareMinX = new Function('a', 'b', compareArr.join(format[0]));\n this.compareMinY = new Function('a', 'b', compareArr.join(format[1]));\n\n this.toBBox = new Function('a',\n 'return {minX: a' + format[0] +\n ', minY: a' + format[1] +\n ', maxX: a' + format[2] +\n ', maxY: a' + format[3] + '};');\n }\n};\n\nfunction findItem(item, items, equalsFn) {\n if (!equalsFn) return items.indexOf(item);\n\n for (var i = 0; i < items.length; i++) {\n if (equalsFn(item, items[i])) return i;\n }\n return -1;\n}\n\n// calculate node's bbox from bboxes of its children\nfunction calcBBox(node, toBBox) {\n distBBox(node, 0, node.children.length, toBBox, node);\n}\n\n// min bounding rectangle of node children from k to p-1\nfunction distBBox(node, k, p, toBBox, destNode) {\n if (!destNode) destNode = createNode(null);\n destNode.minX = Infinity;\n destNode.minY = Infinity;\n destNode.maxX = -Infinity;\n destNode.maxY = -Infinity;\n\n for (var i = k, child; i < p; i++) {\n child = node.children[i];\n extend(destNode, node.leaf ? toBBox(child) : child);\n }\n\n return destNode;\n}\n\nfunction extend(a, b) {\n a.minX = Math.min(a.minX, b.minX);\n a.minY = Math.min(a.minY, b.minY);\n a.maxX = Math.max(a.maxX, b.maxX);\n a.maxY = Math.max(a.maxY, b.maxY);\n return a;\n}\n\nfunction compareNodeMinX(a, b) { return a.minX - b.minX; }\nfunction compareNodeMinY(a, b) { return a.minY - b.minY; }\n\nfunction bboxArea(a) { return (a.maxX - a.minX) * (a.maxY - a.minY); }\nfunction bboxMargin(a) { return (a.maxX - a.minX) + (a.maxY - a.minY); }\n\nfunction enlargedArea(a, b) {\n return (Math.max(b.maxX, a.maxX) - Math.min(b.minX, a.minX)) *\n (Math.max(b.maxY, a.maxY) - Math.min(b.minY, a.minY));\n}\n\nfunction intersectionArea(a, b) {\n var minX = Math.max(a.minX, b.minX),\n minY = Math.max(a.minY, b.minY),\n maxX = Math.min(a.maxX, b.maxX),\n maxY = Math.min(a.maxY, b.maxY);\n\n return Math.max(0, maxX - minX) *\n Math.max(0, maxY - minY);\n}\n\nfunction contains(a, b) {\n return a.minX <= b.minX &&\n a.minY <= b.minY &&\n b.maxX <= a.maxX &&\n b.maxY <= a.maxY;\n}\n\nfunction intersects(a, b) {\n return b.minX <= a.maxX &&\n b.minY <= a.maxY &&\n b.maxX >= a.minX &&\n b.maxY >= a.minY;\n}\n\nfunction createNode(children) {\n return {\n children: children,\n height: 1,\n leaf: true,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n}\n\n// sort an array so that items come in groups of n unsorted items, with groups sorted between each other;\n// combines selection algorithm with binary divide & conquer approach\n\nfunction multiSelect(arr, left, right, n, compare) {\n var stack = [left, right],\n mid;\n\n while (stack.length) {\n right = stack.pop();\n left = stack.pop();\n\n if (right - left <= n) continue;\n\n mid = left + Math.ceil((right - left) / n / 2) * n;\n quickselect(arr, mid, left, right, compare);\n\n stack.push(left, mid, mid, right);\n }\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","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\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 * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","var isObject = require('./isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\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 baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","export const waterLevels = [\r\n 'low',\r\n 'medium',\r\n 'high'\r\n]\r\n\r\nexport const soilQualities = [\r\n 'bad',\r\n 'medium',\r\n 'good'\r\n]\r\n\r\nexport const usageModifiers = {\r\n grain: -0.5,\r\n silo: 0,\r\n biogas: 0.5\r\n}\r\n\r\nexport const usages = Object.keys(usageModifiers)\r\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","\"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","import {makeSetters} from '@helpers/vuex/mutations'\r\nimport {makeSegmentFeatures} from '../helpers'\r\n\r\nexport const defaults = () => ({\r\n wkt: null,\r\n // headland/lane settings, partial field specific\r\n depth: 36,\r\n headlandLanes: 1, // NOTE new\r\n // results from API and subsequent selections\r\n segmentationResult: [],\r\n selectedSegments: [], // headland segment selection, 2d array, outer dimension is ring index, inner array contains selected segment indices\r\n headlands: [],\r\n isHeadlandGenerated: false,\r\n generatedHeadlandLane: 'MULTILINESTRING EMPTY',\r\n segmentLaneTypes: [], // AB or contour per segment, array of lookups {[segmentIndex]: laneType} for each ring\r\n candidateLanes: [],\r\n selectedLane: null,\r\n offset: 0, // NOTE new\r\n skip: false,\r\n subStep: null,\r\n abSegments: [],\r\n selectedAbSegment: null\r\n})\r\n\r\nconst checkValidity = (state, partialState) => {\r\n for (const key in partialState) {\r\n if (!(key in state)) {\r\n console.error(`[lane part data editBuffer] set: property '${key}' does not exist in lane part data defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'selectedSegments',\r\n 'segmentLaneTypes',\r\n 'depth',\r\n 'headlandLanes',\r\n 'isHeadlandGenerated',\r\n 'subStep',\r\n 'abSegments',\r\n 'selectedAbSegment'\r\n ]),\r\n selectAllSegments (state) {\r\n state.selectedSegments = state.segmentationResult.map(ring => {\r\n let i = 0\r\n return ring.map(() => i++)\r\n })\r\n },\r\n deselectAllSegments (state) {\r\n state.selectedSegments = state.segmentationResult.map(() => [])\r\n },\r\n set (state, partData) {\r\n checkValidity(state, partData)\r\n Object.assign(state, partData)\r\n },\r\n reset (state, partData) {\r\n if (partData) {\r\n checkValidity(state, partData)\r\n }\r\n Object.assign(state, defaults(), partData)\r\n }\r\n },\r\n actions: {\r\n findAndSetSelectedSegments ({state, commit, rootGetters}, segmentIds) {\r\n const segmentFeatures = makeSegmentFeatures(state.segmentationResult, state.segmentLaneTypes)\r\n const features = segmentIds.map(id => segmentFeatures.find(x => x.properties.id === id)).sort((b, a) => b.properties.segmentIndex - a.properties.segmentIndex)\r\n\r\n const selectedSegments = state.segmentationResult.map(() => [])\r\n features.forEach(feature => {\r\n const {ringIndex, segmentIndex} = feature.properties\r\n selectedSegments[ringIndex].push(segmentIndex)\r\n })\r\n\r\n commit('setSelectedSegments', selectedSegments)\r\n }\r\n }\r\n}\r\n","import {parse} from 'wellknown'\r\nimport {booleanEqual} from '@turf/turf'\r\n\r\nimport {smarterPost, smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nfunction setAndClearDependentData ({commit}, data) {\r\n if (data.segmentationResult) {\r\n data.selectedSegments = data.segmentationResult.map(() => [])\r\n data.segmentLaneTypes = data.segmentationResult.map((ring, i) => data.segmentationResult[i].map(() => 'line'))\r\n data.headlands = []\r\n data.generatedHeadlandLane = 'MULTILINESTRING EMPTY'\r\n data.candidateLanes = []\r\n } else if (data.headlands) {\r\n data.candidateLanes = []\r\n }\r\n commit('partEditBuffer/set', data)\r\n}\r\n\r\nexport async function getSegmentation ({state, commit, rootGetters}) {\r\n // TODO get saved segmentation for field + partialField index\r\n // TODO on server: clear saved segmentations for partialField indices >= current partialField count\r\n // TODO delete saved segmentation for this field + partialField index + geometry\r\n\r\n return smarterGet('/api/LanePlanning/GetManualSegmentation/{fieldId}/{partFieldIndex}/{totalFieldPartCount}', {\r\n id: 'geotrax.getLanePlansForField',\r\n expiry: 5,\r\n inputs: {\r\n fieldId: () => rootGetters['fieldRecordSystem/fieldId'],\r\n partFieldIndex: () => state.laneEditBuffer.selectedPartIndex,\r\n totalFieldPartCount: () => state.laneEditBuffer.fieldParts.length\r\n },\r\n onResult (segmentation) {\r\n if (segmentation && booleanEqual(parse(segmentation.geometry), parse(state.laneEditBuffer.fieldParts[state.laneEditBuffer.selectedPartIndex].wkt))) {\r\n setAndClearDependentData({commit}, {segmentationResult: segmentation.result})\r\n } else {\r\n return autoSegmentation({state, commit})\r\n }\r\n }\r\n })\r\n}\r\n\r\nexport async function autoSegmentation ({state, commit}) {\r\n const {wkt} = state.partEditBuffer\r\n const {turningCircle} = state.laneEditBuffer\r\n\r\n const data = {\r\n minTurnRadius: turningCircle,\r\n border: wkt\r\n }\r\n return smarterPost('/api/LanePlanning/Segmentation', data, {\r\n id: 'geotrax.segmentation'\r\n })\r\n .then(data => data.result)\r\n .then(segmentationResult => {\r\n setAndClearDependentData({commit}, {segmentationResult})\r\n return segmentationResult\r\n })\r\n}\r\n\r\nexport async function getHeadland ({state, commit, dispatch}) {\r\n const {maxIntoField, turningCircle, gap, workingWidth} = state.laneEditBuffer\r\n const {wkt, segmentationResult, depth, selectedSegments, headlandLanes} = state.partEditBuffer\r\n\r\n const data = {\r\n border: wkt,\r\n segmentationResult,\r\n selectedSegments,\r\n depth,\r\n turnRadius: turningCircle,\r\n maxExtensionIntoField: maxIntoField,\r\n laneWidth: workingWidth,\r\n gap,\r\n headlandLanes\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/Headlands', data, {\r\n id: 'geotrax.headland'\r\n })\r\n .then(headlandsResult => setAndClearDependentData({commit}, {subStep: null, headlands: headlandsResult.headlands, generatedHeadlandLane: headlandsResult.lanes}))\r\n}\r\n\r\nexport async function getABLines ({state, commit}) {\r\n const {workingWidth, minLaneLength, maxLanes, gap, turningCircle} = state.laneEditBuffer\r\n const {wkt, segmentationResult, selectedABSegments, headlands, segmentLaneTypes} = state.partEditBuffer\r\n\r\n const data = {\r\n border: wkt,\r\n segmentationResult,\r\n selectedSegments: selectedABSegments,\r\n width: workingWidth,\r\n gap,\r\n minLength: minLaneLength,\r\n turnRadius: turningCircle,\r\n headlands,\r\n maximumSets: maxLanes,\r\n // todo: refactor and remove pointless mappings\r\n segmentLaneTypes: segmentLaneTypes.map(ring => ring.map(type => type === 'line' ? 'Straight' : 'Contour'))\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/LaneSuggestions', data, {\r\n id: 'geotrax.laneSuggestions'\r\n })\r\n .then(candidateLanes => setAndClearDependentData({commit}, {candidateLanes, selectedLane: 0}))\r\n}\r\n\r\nexport function newAbLine ({state, commit}, offset) {\r\n const abindex = state.partEditBuffer.selectedAbSegment\r\n const selectedAbIndex = state.partEditBuffer.selectedSegments[0].findIndex(x => x === abindex - 1)\r\n if (selectedAbIndex === -1) return\r\n\r\n const abLineString = state.partEditBuffer.abSegments[selectedAbIndex].properties.segmentData.lineString\r\n\r\n const data = {\r\n rawLine: abLineString,\r\n distance: offset\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/MoveAbLane', data, {\r\n id: 'geotrax.moveAbLane'\r\n })\r\n .then(newAbLane => {\r\n const oldAbSegment = state.partEditBuffer.abSegments[selectedAbIndex]\r\n var newAbSegments = state.partEditBuffer.abSegments\r\n const abSegmentCount = newAbSegments.length\r\n const newSegmentIndex = Math.max(...newAbSegments.map(x => x.properties.globalSegmentIndex)) + 1\r\n const copyCount = newAbSegments.filter(x => x.properties.id.includes(oldAbSegment.properties.id)).length\r\n\r\n newAbSegments.push({\r\n geometry: parse(newAbLane),\r\n type: 'Feature',\r\n properties: {\r\n segmentData: {\r\n lineString: newAbLane\r\n },\r\n computed: true,\r\n id: `segment_${oldAbSegment.properties.ringIndex}_${oldAbSegment.properties.segmentIndex}_${copyCount}`,\r\n globalSegmentIndex: newSegmentIndex,\r\n lineType: oldAbSegment.properties.lineType,\r\n arrayIndex: abSegmentCount,\r\n name: `${oldAbSegment.properties.name}_${copyCount}`\r\n }\r\n })\r\n setAndClearDependentData({commit}, {abSegments: newAbSegments})\r\n })\r\n}\r\n\r\nexport function moveLine ({state, commit}, offset) {\r\n const abindex = state.partEditBuffer.selectedAbSegment\r\n const selectedAbIndex = state.partEditBuffer.selectedSegments[0].findIndex(x => x === abindex - 1)\r\n if (selectedAbIndex === -1) return\r\n\r\n const abLineString = state.partEditBuffer.abSegments[selectedAbIndex].properties.segmentData.lineString\r\n\r\n const data = {\r\n rawLine: abLineString,\r\n distance: offset\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/MoveAbLane', data, {\r\n id: 'geotrax.moveAbLane'\r\n })\r\n .then(newAbLane => {\r\n const newAbSegment = state.partEditBuffer.abSegments[selectedAbIndex]\r\n newAbSegment.properties.segmentData.lineString = newAbLane\r\n newAbSegment.geometry = parse(newAbLane)\r\n var newAbSegments = state.partEditBuffer.abSegments\r\n newAbSegments.splice(selectedAbIndex, 1, newAbSegment)\r\n setAndClearDependentData({commit}, {abSegments: newAbSegments})\r\n })\r\n}\r\n\r\nexport function moveLines ({state, commit, dispatch}, offset) {\r\n const {workingWidth, minLaneLength, gap, turningCircle} = state.laneEditBuffer\r\n const {wkt, segmentationResult, headlands, candidateLanes, selectedLane} = state.partEditBuffer\r\n const laneCandidate = candidateLanes[selectedLane]\r\n\r\n const data = {\r\n border: wkt,\r\n segmentationResult,\r\n width: workingWidth,\r\n gap,\r\n offset,\r\n minLength: minLaneLength,\r\n turnRadius: turningCircle,\r\n headlands,\r\n // todo: refactor and remove pointless mappings\r\n ringIndex: laneCandidate.ringIndex,\r\n segmentIndex: laneCandidate.segmentIndex,\r\n laneType: laneCandidate.type\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/MoveLane', data, {\r\n id: 'geotrax.moveLane'\r\n })\r\n .then(newCandidate => {\r\n const newCandidateLanes = [...candidateLanes]\r\n newCandidateLanes.splice(selectedLane, 1, newCandidate)\r\n setAndClearDependentData({commit}, {candidateLanes: newCandidateLanes})\r\n })\r\n}\r\n\r\nexport function splitOrJoinSegment ({state, commit, rootGetters, dispatch}, point) {\r\n const {wkt, segmentationResult, selectedSegments} = state.partEditBuffer\r\n\r\n const data = {\r\n border: wkt,\r\n segmentationResult,\r\n // that is a bug - should be the selected segments?\r\n // selectedSegments: segmentationResult.map(() => []),\r\n selectedSegments,\r\n point\r\n }\r\n return smarterPost('/api/LanePlanning/SplitOrJoinSegments', data, {\r\n id: 'geotrax.editSegments'\r\n })\r\n .then(result => {\r\n // not sure if needed... it's a duplicate\r\n // segments.forEach((ring, ringIndex) => ring.forEach((segment, segmentIndex) => makeFeature({id: `segment_${ringIndex}_${segmentIndex}`, wkt: segment})))\r\n // setAndClearDependentData({commit}, result)\r\n setAndClearDependentData({commit}, {segmentationResult: result.result, selectedSegments: result.selectedSegments})\r\n // TODO save segmentation (result.result) for current field + partialField index + geometry\r\n saveSegmentation({state, rootGetters}, result.result)\r\n })\r\n}\r\n\r\nfunction saveSegmentation ({state, rootGetters}, result) {\r\n const data = {\r\n fieldId: rootGetters['fieldRecordSystem/fieldId'],\r\n partFieldIndex: state.laneEditBuffer.selectedPartIndex,\r\n geometry: state.laneEditBuffer.fieldParts[state.laneEditBuffer.selectedPartIndex].wkt,\r\n result: result\r\n }\r\n return smarterPost('/api/LanePlanning/SaveManualSegmentation', data, {\r\n id: 'geotrax.saveManualSegmentation'\r\n })\r\n}\r\n\r\nexport function resetSegmentation ({state, rootGetters, dispatch}) {\r\n return dispatch('autoSegmentation')\r\n .then(segmentationResult => saveSegmentation(({state, rootGetters}), segmentationResult))\r\n}\r\n","import axios from 'axios'\r\nimport moment from 'moment'\r\nimport {flatten} from 'lodash'\r\nimport {computeSize} from '@helpers/openlayers/computation'\r\nimport {multiLineString} from '@turf/helpers'\r\nimport {parse, stringify} from 'wellknown'\r\n\r\nimport {smarterGet, smarterPost} from '@helpers/vuex/data-loading'\r\nimport {format} from 'src/js/i18n/conversion'\r\nimport {notifications} from 'src/js/infrastructure'\r\nimport {makeFeature, toWkt, splitToPolygons} from 'src/js/helpers/openlayers/features'\r\nimport {defaults as fieldPartDefaults} from '../part-edit-buffer'\r\nimport {createPlanName} from '../helpers'\r\n\r\nexport * from './algorithm'\r\n\r\nexport function loadPrerequisiteDataForPlanning ({dispatch, commit}) {\r\n return Promise.all([\r\n dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {root: true}),\r\n dispatch('fieldRecordSystem/machines/loadMachines', null, {root: true}),\r\n commit('resetLanePlansSelection')\r\n ])\r\n}\r\n\r\nexport async function loadPrerequisiteDataForOverview ({dispatch}) {\r\n await Promise.all([\r\n dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {root: true}),\r\n dispatch('getLanePlansForOrgUnit')\r\n ])\r\n}\r\n\r\nexport function startPlanning ({rootState, state, commit, rootGetters, dispatch}, savedPlan) {\r\n return dispatch('loadPrerequisiteDataForPlanning')\r\n .then(() => {\r\n // transform savedPlan into correct form for edit buffers\r\n if (savedPlan) {\r\n const {settings: {turnRadius: turningCircle, gap, workingWidth}} = savedPlan\r\n\r\n const fieldParts = savedPlan.partialFields.map(partialField => {\r\n const {geometry: wkt, lane: {settings: {offset}}} = partialField\r\n const fieldPartTemplate = {\r\n ...fieldPartDefaults(),\r\n wkt,\r\n offset\r\n }\r\n if (partialField.headland) {\r\n fieldPartTemplate.depth = partialField.headland.settings.depth\r\n fieldPartTemplate.headlandLanes = partialField.headland.settings.headlandLanes\r\n }\r\n return fieldPartTemplate\r\n })\r\n\r\n const templatePlan = {\r\n machine: savedPlan.vehicle ? rootState.fieldRecordSystem.machines.data.machines.find(x => x.id === savedPlan.vehicle.id) : null,\r\n turningCircle,\r\n gap,\r\n workingWidth,\r\n fieldParts,\r\n wkt: savedPlan.fieldGeometry\r\n }\r\n\r\n commit('laneEditBuffer/reset', templatePlan)\r\n commit('partEditBuffer/reset')\r\n } else {\r\n commit('laneEditBuffer/reset')\r\n\r\n const fieldWkt = rootGetters['fieldRecordSystem/fieldWkt']\r\n\r\n return dispatch('setFieldParts', [fieldWkt])\r\n }\r\n })\r\n}\r\n\r\n// field was manually segmented into new partial fields\r\nexport function setFieldParts ({commit, dispatch}, wkts) {\r\n // safeguard against multipolygon geometries\r\n const features = wkts.map(wkt => makeFeature({wkt}))\r\n wkts = splitToPolygons(features).map(toWkt)\r\n\r\n commit('laneEditBuffer/set', {\r\n // any previous results are discarded\r\n fieldParts: wkts.map(wkt => ({...fieldPartDefaults(), wkt})),\r\n selectedPartIndex: 0\r\n })\r\n commit('partEditBuffer/reset')\r\n}\r\n\r\n// can restart wizard for an already completed part, keeping previous settings\r\nexport function startPlanningPart ({state, commit, dispatch}) {\r\n if (state.partEditBuffer.wkt) {\r\n throw new Error('cannot start planning a part if another part is currently in progress')\r\n }\r\n\r\n const {selectedPartIndex, fieldParts} = state.laneEditBuffer\r\n\r\n commit('partEditBuffer/set', fieldParts[selectedPartIndex])\r\n\r\n return dispatch('getSegmentation')\r\n}\r\n\r\nexport async function finishPart ({state, commit, dispatch, getters}, skip = false) {\r\n const fieldParts = [...state.laneEditBuffer.fieldParts]\r\n fieldParts.splice(state.laneEditBuffer.selectedPartIndex, 1, {...state.partEditBuffer, skip})\r\n\r\n const nextPart = fieldParts.find(x => !x.skip && (getters.isPlanningProfileAB ? !x.abSegments.length : !x.candidateLanes.length))\r\n\r\n commit('laneEditBuffer/set', {\r\n fieldParts\r\n })\r\n\r\n if (nextPart) {\r\n commit('laneEditBuffer/set', {\r\n selectedPartIndex: nextPart ? fieldParts.indexOf(nextPart) : null\r\n })\r\n commit('partEditBuffer/reset')\r\n\r\n return dispatch('startPlanningPart')\r\n } else {\r\n return dispatch('finishPlanning')\r\n }\r\n}\r\n\r\nexport function cancelPart ({state, dispatch}) {\r\n // currently it is not possible to just cancel one partial field, all planned parts are cancelled at once to return to the common settings page\r\n return dispatch('setFieldParts', state.laneEditBuffer.fieldParts.map(x => x.wkt))\r\n}\r\n\r\nexport async function finishPlanning ({commit, dispatch, getters, rootGetters}) {\r\n if (!getters.isPlanningProfileAB) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n return dispatch('getLanePlanNamesForField', fieldId)\r\n .then(() => {\r\n dispatch('saveLanePlan')\r\n })\r\n .then(() => {\r\n commit('laneEditBuffer/set', {finished: true})\r\n })\r\n } else {\r\n return dispatch('saveLanePlanAb')\r\n .then(() => {\r\n commit('laneEditBuffer/set', {finished: true})\r\n })\r\n }\r\n}\r\n\r\nexport function stopPlanning ({commit}) {\r\n commit('laneEditBuffer/reset')\r\n commit('partEditBuffer/reset')\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n}\r\n\r\nexport function startEditingFieldGeometry ({state, commit, dispatch}, {features}) {\r\n return dispatch('fieldRecordSystem/map/startExpertMode', features, {root: true}).then(() => {\r\n commit('fieldRecordSystem/map/setMode', 'cut', {root: true})\r\n })\r\n}\r\n\r\nexport function commitEditedFieldGeometry ({dispatch}) {\r\n return dispatch('fieldRecordSystem/map/stopEditing', null, {root: true})\r\n .then(features => features.map(toWkt))\r\n .then(wkts => dispatch('setFieldParts', wkts))\r\n}\r\n\r\nexport function undo () {\r\n notifications.info('lanePlanning undo not yet implemented')\r\n}\r\n\r\nexport function saveLanePlanAb ({state, commit, rootState, rootGetters}) {\r\n const laneEditBuffer = state.laneEditBuffer\r\n const userSettings = rootState.fieldRecordSystem.userSettings\r\n const entityId = rootGetters['fieldRecordSystem/fieldId']\r\n const fieldGeometry = rootGetters['fieldRecordSystem/fieldWkt']\r\n\r\n const generatedAt = moment().toISOString()\r\n let plans = []\r\n\r\n for (const fieldPart of laneEditBuffer.fieldParts.filter(x => !x.skip)) {\r\n let segmentGeometries = fieldPart.segmentationResult.reduce((a, b) => a.concat(b))\r\n segmentGeometries = segmentGeometries.map(s => parse(s.lineString))\r\n segmentGeometries = segmentGeometries.map(geometry => geometry.coordinates)\r\n\r\n const plan = fieldPart.abSegments.map(segment => ({\r\n Id: null,\r\n entityId,\r\n harvestYear: userSettings.harvestYear,\r\n fieldGeometry,\r\n generatedAt,\r\n\r\n partialFieldId: null,\r\n fieldPartGeometry: fieldPart.wkt,\r\n segmentGeometries: stringify(multiLineString(segmentGeometries)),\r\n\r\n abLineId: null,\r\n length: computeSize(segment.geometry),\r\n type: segment.properties.lineType === 'line' ? 'AbStraight' : 'AbContour',\r\n abLine: segment.properties.segmentData.lineString,\r\n name: segment.properties.name\r\n }))\r\n plans.push(plan)\r\n }\r\n plans = plans.reduce((acc, cur) => acc.concat(cur))\r\n return smarterPost('/api/LanePlanning/SaveLanePlanAb', plans, {\r\n id: 'geotrax.savePlanAb'\r\n })\r\n .then(plans => {\r\n commit('addLanePlansOrgUnit', plans)\r\n state.data.selectedLanePlans = plans.map(x => x.id)\r\n })\r\n}\r\n\r\nexport function saveLanePlan ({state, commit, rootState, rootGetters}) {\r\n const laneEditBuffer = state.laneEditBuffer\r\n const userSettings = rootState.fieldRecordSystem.userSettings\r\n const entityId = rootGetters['fieldRecordSystem/fieldId']\r\n const fieldGeometry = rootGetters['fieldRecordSystem/fieldWkt']\r\n const field = rootGetters['fieldRecordSystem/navigation/entityLookup'][entityId]\r\n const lanePlanNamesField = state.data.lanePlanNamesForField\r\n\r\n const fieldName = field.name + '_'\r\n const workingWidthName = laneEditBuffer.workingWidth ? format(laneEditBuffer.workingWidth, 'f2') + 'm_' : ''\r\n const laneTypeName = 'Lines'\r\n\r\n const name = createPlanName(lanePlanNamesField, fieldName + workingWidthName + laneTypeName)\r\n\r\n const plan = {\r\n id: null,\r\n entityId,\r\n\r\n vehicle: laneEditBuffer.machineId ? {id: laneEditBuffer.machineId} : null,\r\n\r\n harvestYear: userSettings.harvestYear,\r\n fieldGeometry,\r\n generatedAt: moment().toISOString(),\r\n name,\r\n\r\n settings: {\r\n planId: null,\r\n workingWidth: laneEditBuffer.workingWidth,\r\n gap: laneEditBuffer.gap,\r\n turnRadius: laneEditBuffer.turningCircle,\r\n targetSystem: null // TODO targetSystem does not exist anymore change backend to planning profile\r\n },\r\n\r\n partialFields: []\r\n }\r\n\r\n for (const fieldPart of laneEditBuffer.fieldParts.filter(x => !x.skip)) {\r\n let headland = null\r\n\r\n if (fieldPart.headlands.length > 0) {\r\n headland = {\r\n partialFieldId: null,\r\n geometries: fieldPart.headlands,\r\n laneGeometry: fieldPart.generatedHeadlandLane,\r\n\r\n settings: {\r\n headlandId: null,\r\n depth: fieldPart.depth,\r\n workingWidth: laneEditBuffer.workingWidth,\r\n gap: laneEditBuffer.gap,\r\n turnRadius: laneEditBuffer.turningCircle,\r\n minLaneLength: laneEditBuffer.turningCircle * 2, // atm unused: laneEditBuffer.minLaneLength,\r\n maxExtensionIntoField: fieldPart.depth * 2, // atm unused: laneEditBuffer.maxIntoField,\r\n maxLanes: null\r\n }\r\n }\r\n }\r\n\r\n const suggestion = fieldPart.candidateLanes[fieldPart.selectedLane]\r\n const lane = {\r\n partialFieldId: null,\r\n lineGeometries: suggestion.lines,\r\n length: suggestion.totalDistance,\r\n turnsPerDistance: suggestion.turnsPerDistance,\r\n type: suggestion.type,\r\n // todo: atm warnings is just an int, but it'll be a MultiLineString or LineString[] suggestion.warnings,\r\n warnings: 'MULTILINESTRING EMPTY',\r\n // todo: algorithm has to deliver the segment\r\n segment: fieldPart.segmentationResult[suggestion.ringIndex][suggestion.segmentIndex].lineString,\r\n\r\n settings: {\r\n laneId: null,\r\n minLaneLength: laneEditBuffer.turningCircle * 2, // atm unused: laneEditBuffer.minLaneLength,\r\n maxLanes: null, // atm unused: laneEditBuffer.maxLanes,\r\n offset: suggestion.offset\r\n }\r\n }\r\n\r\n const part = {\r\n id: null,\r\n planId: null,\r\n geometry: fieldPart.wkt,\r\n segmentGeometries: flatten(fieldPart.segmentationResult).map(s => s.lineString),\r\n headland,\r\n lane\r\n }\r\n\r\n plan.partialFields.push(part)\r\n }\r\n\r\n return smarterPost('/api/LanePlanning/SaveLanePlan', plan, {\r\n id: 'geotrax.savePlan'\r\n })\r\n .then(plans => {\r\n commit('addLanePlansOrgUnit', [plans])\r\n state.data.selectedLanePlans = [plans.id]\r\n })\r\n}\r\n\r\nexport async function getDataForStepLaneSelection ({state, dispatch, rootGetters, commit}) {\r\n const isAB = rootGetters['fieldRecordSystem/lanePlanning/isPlanningProfileAB']\r\n\r\n await dispatch('getLanePlansForField') // TODO find out why this is called\r\n\r\n if (isAB) {\r\n commit('partEditBuffer/setSubStep', 'preview')\r\n } else {\r\n return dispatch('getABLines')\r\n }\r\n}\r\n\r\nexport function getLanePlanNamesForField ({rootGetters, commit}, fieldId) {\r\n return smarterGet('/api/LanePlanning/{fieldId}/LanePlanNames', {\r\n id: 'geotrax.getLanePlanNamesForField',\r\n expiry: 0,\r\n inputs: {\r\n fieldId: () => fieldId\r\n },\r\n onResult (lanePlanNames) {\r\n commit('setLanePlanNamesForField', lanePlanNames)\r\n }\r\n })\r\n}\r\n\r\nexport function getLanePlansForField ({rootGetters, commit}) {\r\n return smarterGet('/api/LanePlanning/{fieldId}/LanePlans', {\r\n id: 'geotrax.getLanePlansForField',\r\n expiry: 5,\r\n inputs: {\r\n fieldId: () => rootGetters['fieldRecordSystem/fieldId']\r\n },\r\n onResult (lanePlans) {\r\n commit('setLanePlansForField', lanePlans)\r\n }\r\n })\r\n}\r\n\r\nexport async function getLanePlansForOrgUnit ({rootGetters, commit}) {\r\n return smarterGet([\r\n '/api/LanePlanning/{orgUnitId}/LanePlansByOrgUnit',\r\n '/api/LanePlanning/{orgUnitId}/AbLanePlansByOrgUnit'\r\n ], {\r\n id: 'geotrax.LanePlansByOrgUnit',\r\n expiry: 5,\r\n inputs: {\r\n orgUnitId: () => rootGetters['fieldRecordSystem/orgUnitId']\r\n },\r\n onResult ([lanePlans, abLanePlans]) {\r\n commit('setLanePlansOrgUnit', lanePlans)\r\n commit('addLanePlansOrgUnit', abLanePlans)\r\n }\r\n })\r\n}\r\n\r\n// wip\r\nexport function download ({rootState, state, rootGetters}) {\r\n const lanePlanIds = state.data.selectedLanePlans.filter(x => x)\r\n const data = {\r\n fileName: generateFileName(rootState, state, rootGetters, lanePlanIds),\r\n planIds: lanePlanIds,\r\n harvestYear: rootState.fieldRecordSystem.userSettings.harvestYear,\r\n includeBorder: state.laneEditBuffer.isBorderSelected,\r\n includeHeadland: state.laneEditBuffer.isHeadlandSelected,\r\n includeHeadlandLanes: state.laneEditBuffer.isHeadlandLanesSelected,\r\n includeInfieldLanes: state.laneEditBuffer.includeInfieldLanes,\r\n includeBorderAsCurve: state.laneEditBuffer.includeBorderAsCurve\r\n }\r\n\r\n return smarterPost(`/api/DataTransfer/Lane/Prepare/${state.ui.selection.format}`, data, {\r\n id: 'geotrax.download'\r\n })\r\n .then(response => {\r\n window.location.href = window.location.href.replace(window.location.pathname, `/api/DataTransfer/Lane/Download/${response}`)\r\n })\r\n}\r\n\r\nfunction generateFileName (rootState, state, rootGetters, planIds) {\r\n let fileName = ''\r\n\r\n const orgUnitName = rootGetters['fieldRecordSystem/orgUnitName']\r\n const fieldName = rootGetters['fieldRecordSystem/fieldName']\r\n const entityLookup = rootGetters['fieldRecordSystem/entityNameLookup']\r\n\r\n if (Object.keys(state.data.lanePlansOrgUnit).length) {\r\n const plans = Object.values(state.data.lanePlansOrgUnit).reduce((acc, cur) => acc.concat(cur))\r\n const lanePlans = planIds.map(id => plans.filter(plan => plan.id === id)).reduce((acc, cur) => acc.concat(cur))\r\n const date = lanePlans.length > 1\r\n ? moment.utc().add(1, 'hours').format('YYYY-MM-DD_HH-mm-ss')\r\n : moment.utc(lanePlans[0].generatedAt).format('YYYY-MM-DD_HH-mm-ss')\r\n\r\n if (lanePlans.length > 1) {\r\n fileName = date + '_' + rootState.i18n.translations['Areas.LanePlanning.SR_LanePlanning']['MultipleExportName']\r\n } else {\r\n let formerName = entityLookup[lanePlans[0].entityId] + '_'\r\n if (lanePlans[0].settings !== undefined) {\r\n let workingWidth = lanePlans[0].settings.workingWidth !== undefined ? lanePlans[0].settings.workingWidth : 'Lines'\r\n workingWidth = format(workingWidth, 'f2')\r\n if (workingWidth !== 'Lines') {\r\n workingWidth = workingWidth.replace('.', ',')\r\n workingWidth = workingWidth.concat('m_Lines')\r\n }\r\n formerName = formerName.concat(workingWidth)\r\n } else {\r\n let abType = lanePlans[0].type !== undefined ? lanePlans[0].type.name : 'AB'\r\n formerName = formerName.concat(abType)\r\n }\r\n\r\n fileName = formerName === lanePlans[0].name ? date + '_' + orgUnitName + '_' + lanePlans[0].name : date + '_' + lanePlans[0].name\r\n }\r\n } else {\r\n const date = moment().format('YYYY-MM-DD_HH-mm-ss')\r\n let workingWidth = state.laneEditBuffer.workingWidth !== undefined ? state.laneEditBuffer.workingWidth : 'Lines'\r\n workingWidth = format(workingWidth, 'f2')\r\n if (workingWidth !== 'Lines') {\r\n workingWidth = workingWidth.replace('.', ',').concat('m_Lines')\r\n }\r\n fileName = date + '_' + orgUnitName + '_' + fieldName + '_' + workingWidth\r\n }\r\n\r\n return fileName\r\n}\r\n\r\nexport function resetLanePlansSelection ({dispatch, commit}) {\r\n dispatch('stopPlanning')\r\n .then(commit('resetLanePlansSelection'))\r\n}\r\nexport function deleteLanePlans ({state, commit, dispatch}) {\r\n const selectedLanePlans = state.data.selectedLanePlans\r\n\r\n return Promise.all(\r\n selectedLanePlans.map(planId => axios.delete(`/api/LanePlanning/${planId}`))\r\n )\r\n .then(() => {\r\n commit('resetLanePlansSelection')\r\n dispatch('fieldRecordSystem/lanePlanning/getLanePlansForOrgUnit', null, {root: true})\r\n })\r\n}\r\n\r\nexport function updateLanePlanName ({state, commit}, {entityId, planId, name}) {\r\n const previousName = state.data.lanePlansOrgUnit[entityId].find(plan => plan.id === planId).name\r\n commit('updateLanePlanName', {entityId, planId, name})\r\n return axios.put(`/api/LanePlanning/UpdateName/${planId}/${name}`)\r\n .catch(error => {\r\n commit('updateLanePlanName', {entityId, planId, name: previousName})\r\n throw error\r\n })\r\n}\r\n","import Vue from 'vue'\r\nimport {groupBy} from 'lodash'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst mutations = {\r\n ...makeSetters([\r\n 'ui.selection.isFromDetailsView',\r\n 'ui.selection.format',\r\n 'ui.planning.step',\r\n 'ui.features.partialFieldFeatures',\r\n 'ui.features.segmentFeatures',\r\n 'ui.features.headlandFeatures',\r\n 'ui.features.headlandLaneFeatures',\r\n 'ui.features.laneFeatures',\r\n 'data.lanePlanNamesForField'\r\n ]),\r\n setIsCreateAbLineActive (state, active) {\r\n state.ui.isCreateAbLineActive = active\r\n state.ui.hideFooter = active\r\n },\r\n setLanePlansForField (state, lanePlans) {\r\n state.data.lanePlansField = {}\r\n lanePlans.forEach(lanePlan => {\r\n Vue.set(state.data.lanePlansField, lanePlan.id, lanePlan)\r\n })\r\n },\r\n setSelectedPlanId (state, id) {\r\n state.ui.selection.planId = id\r\n },\r\n setLanePlans (state, {fieldId, lanePlans}) {\r\n Vue.set(state.data.lanePlansOrgUnit, fieldId, lanePlans.length ? lanePlans : null)\r\n },\r\n setLanePlanId (state, planId) {\r\n let data = JSON.parse(JSON.stringify(state.data.selectedLanePlans))\r\n if (!data.includes(planId)) {\r\n data.push(planId)\r\n } else {\r\n data = data.filter(id => id !== planId)\r\n }\r\n state.data.selectedLanePlans = data\r\n },\r\n setSelectedLanePlan (state, plan) {\r\n state.data.selectedPlan = plan\r\n },\r\n setLanePlansOrgUnit (state, lanePlans) {\r\n state.data.lanePlansOrgUnit = groupBy(lanePlans, 'entityId')\r\n state.data.totalNumberOfPlans = lanePlans.length\r\n },\r\n addLanePlansOrgUnit (state, lanePlans) {\r\n const plans = groupBy(lanePlans, 'entityId')\r\n const lookup = {\r\n ...state.data.lanePlansOrgUnit\r\n }\r\n\r\n Object.keys(plans).forEach(key => {\r\n if (!lookup[key]) {\r\n lookup[key] = []\r\n }\r\n lookup[key].push(...plans[key])\r\n })\r\n\r\n state.data.lanePlansOrgUnit = lookup\r\n state.data.totalNumberOfPlans += lanePlans.length\r\n },\r\n resetLanePlansSelection (state) {\r\n state.data.selectedLanePlans = []\r\n state.data.selectedPlan = null\r\n state.data.lanePlansOrgUnit = {}\r\n state.data.totalNumberOfPlans = 0\r\n state.data.expandedNodes = []\r\n state.data.selectedNodes = []\r\n },\r\n toggleExpanded (state, id) {\r\n if (state.data.expandedNodes.includes(id)) {\r\n state.data.expandedNodes = state.data.expandedNodes.filter(x => x !== id)\r\n } else {\r\n const data = state.data.expandedNodes\r\n data.push(id)\r\n state.data.expandedNodes = data\r\n }\r\n },\r\n toggleSelected (state, id) {\r\n if (state.data.selectedNodes.includes(id)) {\r\n state.data.selectedNodes = state.data.selectedNodes.filter(x => x !== id)\r\n } else {\r\n const data = state.data.selectedNodes\r\n data.push(id)\r\n state.data.selectedNodes = data\r\n }\r\n },\r\n updateLanePlanName (state, {entityId, planId, name}) {\r\n state.data.lanePlansOrgUnit[entityId].find(plan => plan.id === planId).name = name\r\n }\r\n}\r\n\r\nexport default mutations\r\n","// ui control flow\r\nimport {toObject} from '@helpers/reducers'\r\n\r\nexport const wizardActive = state => state.partEditBuffer.wkt !== null\r\n\r\nexport const done = state => state.laneEditBuffer.fieldParts.every(x => x.selectedLane)\r\n\r\nexport const globalSegmentIndicesForCandidateLanes = state => {\r\n let index = 1\r\n return state.partEditBuffer.segmentationResult.map((ring) => ring.map(() => index++))\r\n}\r\n\r\nexport const canSave = (state, getters) => {\r\n const abLinesAvailable = !!state.partEditBuffer.abSegments.length\r\n const linesAvailable = !!state.partEditBuffer.candidateLanes.length\r\n\r\n return getters.isPlanningProfileAB ? abLinesAvailable : linesAvailable\r\n}\r\n\r\nexport function tree (state, getters, rootState, rootGetters) {\r\n const orgUnit = rootGetters['fieldRecordSystem/orgUnit']\r\n\r\n if (!orgUnit) return null\r\n\r\n const lanePlans = state.data.lanePlansOrgUnit\r\n\r\n const cloneNode = (node) => {\r\n const {id, name, type, children} = node\r\n\r\n let lanePlansForNode = lanePlans[id]\r\n if (lanePlansForNode) {\r\n lanePlansForNode = lanePlansForNode.map(plan => {\r\n return {\r\n id: plan.id,\r\n content: {\r\n ...plan,\r\n type: 'plan'\r\n },\r\n selected: state.data.selectedNodes.includes(plan.id),\r\n expanded: null\r\n }\r\n }).sort((a, b) => a.content.name.localeCompare(b.content.name))\r\n }\r\n\r\n const clone = {\r\n id,\r\n content: {\r\n id,\r\n name,\r\n type\r\n },\r\n children,\r\n selected: state.data.selectedNodes.includes(id),\r\n expanded: state.data.expandedNodes.includes(id)\r\n }\r\n\r\n if (lanePlansForNode) {\r\n clone.children = lanePlansForNode\r\n } else if (children) {\r\n clone.children = children.map(cloneNode).sort((a, b) => a.content.name.localeCompare(b.content.name))\r\n }\r\n\r\n return clone\r\n }\r\n\r\n return cloneNode(orgUnit)\r\n}\r\n\r\nexport function availableMachines (rootState) {\r\n const machines = rootState.fieldRecordSystem.machines.data.machines\r\n if (!machines.length) return {}\r\n\r\n return machines.map(machine => [machine.id, {\r\n id: machine.id,\r\n name: machine.name,\r\n workingWidth: machine.workingWidth,\r\n turningCircle: machine.turningCircle\r\n }]).reduce(toObject, {})\r\n}\r\n\r\nexport function isPlanningProfileAB (state) {\r\n return state.laneEditBuffer.planningProfile && state.laneEditBuffer.planningProfile === 'ab'\r\n}\r\n\r\nexport function moreFieldPartsExist (state) {\r\n return state.laneEditBuffer.fieldParts.length > 1\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n // machine settings, planning specific\r\n planningProfile: 'ab',\r\n machineId: null,\r\n workingWidth: 6,\r\n turningCircle: 15,\r\n gap: 0, // distance between lanes\r\n\r\n fieldParts: [], // field or partial fields\r\n selectedPartIndex: null,\r\n finished: false,\r\n\r\n // download settings\r\n isBorderSelected: true,\r\n includeBorderAsCurve: true,\r\n isHeadlandSelected: true,\r\n isHeadlandLanesSelected: true,\r\n includeInfieldLanes: true,\r\n\r\n isOneFileSelected: true\r\n})\r\n\r\nconst checkValidity = (state, partialState) => {\r\n for (const key in partialState) {\r\n if (!(key in state)) {\r\n console.error(`[lane data editBuffer] set: property '${key}' does not exist in lane data defaults`)\r\n }\r\n }\r\n}\r\n\r\nconst setMachineParameters = (state, laneData) => {\r\n if (!laneData.machine) return\r\n\r\n if (laneData.machine.workingWidth) {\r\n state.workingWidth = laneData.machine.workingWidth\r\n }\r\n if (laneData.machine.turningCircle) {\r\n state.turningCircle = laneData.machine.turningCircle\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'gap',\r\n 'machineId',\r\n 'workingWidth',\r\n 'turningCircle',\r\n 'planningProfile',\r\n 'isBorderSelected',\r\n 'includeBorderAsCurve',\r\n 'isHeadlandSelected',\r\n 'isHeadlandLanesSelected',\r\n 'includeInfieldLanes',\r\n 'isOneFileSelected'\r\n ]),\r\n set (state, laneData) {\r\n checkValidity(state, laneData)\r\n Object.assign(state, laneData)\r\n setMachineParameters(state, laneData)\r\n },\r\n reset (state, laneData) {\r\n if (laneData) {\r\n checkValidity(state, laneData)\r\n }\r\n Object.assign(state, defaults(), laneData)\r\n if (laneData) {\r\n setMachineParameters(state, laneData)\r\n }\r\n }\r\n },\r\n actions: {\r\n setMachineData ({commit, rootGetters}, machineId) {\r\n const machines = rootGetters['fieldRecordSystem/lanePlanning/availableMachines']\r\n commit('setWorkingWidth', machines[machineId].workingWidth)\r\n commit('setTurningCircle', machines[machineId].turningCircle)\r\n }\r\n }\r\n}\r\n","import * as actions from './actions'\r\nimport mutations from './mutations'\r\nimport * as getters from './getters'\r\nimport laneEditBuffer from './lane-edit-buffer'\r\nimport partEditBuffer from './part-edit-buffer'\r\n\r\nconst state = {\r\n data: {\r\n lanePlansField: {}, // keyed by lane id\r\n planningProfiles: ['ab', 'line'],\r\n targetSystems: ['Shape', 'MuellerShape', 'ISOXML', 'ISOXML_v4', 'Topcon', 'Trimble', 'TrimblePIQ'],\r\n selectedLanePlans: [],\r\n lanePlansOrgUnit: {},\r\n totalNumberOfPlans: 0,\r\n selectedPlan: null,\r\n expandedNodes: [],\r\n selectedNodes: [],\r\n lanePlanNamesForField: []\r\n },\r\n ui: {\r\n isCreateAbLineActive: false,\r\n hideFooter: false,\r\n selection: {\r\n planId: '',\r\n isFromDetailsView: false,\r\n format: 'Shape'\r\n },\r\n planning: {\r\n step: null\r\n },\r\n features: {\r\n partialFieldFeatures: [],\r\n segmentFeatures: [],\r\n headlandFeatures: [],\r\n headlandLaneFeatures: [],\r\n laneFeatures: []\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n getters,\r\n actions,\r\n mutations,\r\n modules: {\r\n laneEditBuffer,\r\n partEditBuffer\r\n }\r\n}\r\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\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 * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\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 baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nmodule.exports = baseMatchesProperty;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","export function fromFields (fields, fieldDataLookup) {\r\n return fields\r\n .reduce((features, field) => {\r\n const data = fieldDataLookup[field.id]\r\n\r\n if (!data || !data.geometry) return features\r\n\r\n const {geometry} = data\r\n\r\n features.push({\r\n type: 'Feature',\r\n properties: {\r\n id: field.id,\r\n name: field.name\r\n },\r\n geometry\r\n })\r\n\r\n return features\r\n }, [])\r\n}\r\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}","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\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","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\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","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\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","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nmodule.exports = matchesStrictComparable;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var baseEach = require('./_baseEach');\n\n/**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n}\n\nmodule.exports = baseAggregator;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","\"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 {\r\n if (!cultivation) {\r\n return ''\r\n }\r\n\r\n const frsTranslations = store.state.i18n.translations['Areas.FieldRecordSystem.SR_FieldRecordSystem']\r\n\r\n switch (cultivation.type) {\r\n case 'main':\r\n case 'secondary': {\r\n const name = store.state.i18n.translations['masterData.crops.usage'][`${cultivation.cropUsageId}_name`]\r\n\r\n return frsTranslations[`CultivationType_${cultivation.type}`]\r\n ? typeof name === 'string'\r\n ? `${frsTranslations[`CultivationType_${cultivation.type}`]} - ${name}`\r\n : frsTranslations[`CultivationType_${cultivation.type}`].toString()\r\n : null\r\n }\r\n case 'catch': {\r\n const frsTranslations = store.state.i18n.translations['Areas.FieldRecordSystem.SR_FieldRecordSystem']\r\n return cultivation.mixtureComponents ? toMixtureName(cultivation.mixtureComponents) : frsTranslations.CatchCrop\r\n }\r\n case 'eco':\r\n return frsTranslations.EcologicalPriorityAreas\r\n case 'dual':\r\n return frsTranslations.TwoCropUsage ? frsTranslations.TwoCropUsage.concat(` - ${'a'} + ${'b'}`) : null\r\n default:\r\n throw new Error(frsTranslations.InvalidCultivationType.concat(`: ${cultivation.type}`))\r\n }\r\n}\r\n\r\nexport const toMixtureName = (components) => {\r\n const sorted = orderBy(components, ['percentage', 'cropUsageId'], ['desc', 'asc'])\r\n const componentsShort = sorted.map((component) => {\r\n const name = store.state.i18n.translations['masterData.crops.usage'][`${component.cropUsageId}_name`]\r\n return `${name} (${format(component.percentage, 'percent')})`\r\n })\r\n return componentsShort.join(', ')\r\n}\r\n\r\nexport const isEcoCompatible = (components) => {\r\n return Math.max(...components.map(x => x.percentage)) < 0.6\r\n}\r\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","module.exports = function() {\n throw new Error('call .point() or .polygon() instead');\n};\n\nfunction position(bbox) {\n if (bbox) return coordInBBBOX(bbox);\n else return [lon(), lat()];\n}\n\nmodule.exports.position = position;\n\nmodule.exports.point = function(count, bbox) {\n var features = [];\n for (i = 0; i < count; i++) {\n features.push(feature(bbox ? point(position(bbox)) : point()));\n }\n return collection(features);\n};\n\nmodule.exports.polygon = function(count, num_vertices, max_radial_length, bbox) {\n if (typeof num_vertices !== 'number') num_vertices = 10;\n if (typeof max_radial_length !== 'number') max_radial_length = 10;\n var features = [];\n for (i = 0; i < count; i++) {\n var vertices = [],\n circle_offsets = Array.apply(null,\n new Array(num_vertices + 1)).map(Math.random);\n\n circle_offsets.forEach(sumOffsets);\n circle_offsets.forEach(scaleOffsets);\n vertices[vertices.length - 1] = vertices[0]; // close the ring\n\n // center the polygon around something\n vertices = vertices.map(vertexToCoordinate(position(bbox)));\n features.push(feature(polygon([vertices])));\n }\n\n function sumOffsets(cur, index, arr) {\n arr[index] = (index > 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","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\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","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\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","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","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","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","/**\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","const normalFactors = {\r\n phosphorus: 0.4364253538112,\r\n magnesium: 0.603136308858,\r\n potassium: 0.8298755186722\r\n}\r\n\r\nconst oxideFactors = {\r\n phosphorus: 2.291342588755,\r\n magnesium: 1.6580,\r\n potassium: 1.2050\r\n}\r\n\r\nexport const calculateToOxidform = (nutrient, value) => {\r\n return oxideFactors[nutrient] * value\r\n}\r\n\r\nexport const calculateFromOxidform = (nutrient, value) => {\r\n return normalFactors[nutrient] * value\r\n}\r\n\r\nexport const oxideNames = {\r\n potassium: 'K₂O',\r\n phosphorus: 'P₂O₅',\r\n magnesium: 'MgO'\r\n}\r\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\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 getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\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 getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\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 isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nmodule.exports = getMatchData;\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 addMethods(worker, methods) {\n var c = 0;\n var callbacks = {};\n worker.addEventListener('message', function (e) {\n var d = e.data;\n if (d.type !== 'RPC') \n { return; }\n if (d.id) {\n var f = callbacks[d.id];\n if (f) {\n delete callbacks[d.id];\n if (d.error) {\n f[1](Object.assign(Error(d.error.message), d.error));\n } else {\n f[0](d.result);\n }\n }\n } else {\n var evt = document.createEvent('Event');\n evt.initEvent(d.method, false, false);\n evt.data = d.params;\n worker.dispatchEvent(evt);\n }\n });\n methods.forEach(function (method) {\n worker[method] = (function () {\n var params = [], len = arguments.length;\n while ( len-- ) params[ len ] = arguments[ len ];\n\n return new Promise(function (a, b) {\n var id = ++c;\n callbacks[id] = [a,b];\n worker.postMessage({\n type: 'RPC',\n id: id,\n method: method,\n params: params\n });\n });\n });\n });\n}\n\nmodule.exports = addMethods;\n//# sourceMappingURL=rpc-wrapper.js.map\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","import parse from 'wellknown'\r\nimport {seperateMultiLineFeatureToLineFeatures} from 'src/js/helpers/openlayers/features'\r\nimport {makeFeature} from '@helpers/openlayers/features'\r\n\r\nexport const createPlanName = (names, tempName) => {\r\n let i = 0\r\n while (names.find(planName => i === 0 ? planName === tempName : planName === `${tempName}_${i}`)) {\r\n i++\r\n }\r\n return i === 0 ? tempName : `${tempName}_${i}`\r\n}\r\n\r\nexport const extractFeatures = (source, mappingFunc) =>\r\n source.map(x => mappingFunc(x))\r\n .filter(x => x !== null)\r\n .reduce((acc, cur) => acc.concat(cur), [])\r\n .map(wkt => makeFeature({wkt}))\r\n\r\nexport const makePartialFieldFeatures = (selectedPartIndex, fieldParts) => fieldParts\r\n .map(({wkt, skip, candidateLanes}, i) => skip ? null : ({\r\n geometry: parse(wkt),\r\n type: 'Feature',\r\n properties: {\r\n id: i,\r\n i,\r\n selected: selectedPartIndex === i,\r\n finished: candidateLanes.length && i !== selectedPartIndex\r\n }\r\n })).filter(x => x)\r\n\r\nexport const makeSegmentFeatures = (segmentationResults, segmentLaneTypes) => segmentationResults\r\n .map((ring, i) => ring\r\n .map((segment, j) => ({\r\n geometry: parse(segment.lineString),\r\n type: 'Feature',\r\n properties: {\r\n id: `segment_${i}_${j}`,\r\n ringIndex: i,\r\n segmentIndex: j,\r\n globalSegmentIndex: 1 + i + j,\r\n lineType: segmentLaneTypes[i][j]\r\n }\r\n }))).reduce((accumulator, current) => accumulator.concat(current), [])\r\n\r\nexport const makeParts = (partEditBuffer, selectedPartIndex, fieldParts) => (partEditBuffer.wkt\r\n ? fieldParts.filter((part, i) => i !== selectedPartIndex).concat([partEditBuffer])\r\n : fieldParts).filter(x => !x.skip)\r\n\r\nexport const makeHeadlandFeatures = (selectedPartIndex, parts) => parts\r\n .map((part, i) => part.headlands\r\n .map((wkt, index) => ({\r\n geometry: parse(wkt),\r\n type: 'Feature',\r\n properties: {\r\n id: `headland_${index}`,\r\n selected: i === selectedPartIndex\r\n }\r\n }))).reduce((accumulator, current) => accumulator.concat(current), [])\r\n\r\nexport const makeHeadlandLaneFeatures = (selectedPartIndex, parts) => parts\r\n .map((part, i) => seperateMultiLineFeatureToLineFeatures({\r\n geometry: parse(part.generatedHeadlandLane),\r\n type: 'Feature',\r\n properties: {\r\n id: i,\r\n selected: i === selectedPartIndex\r\n }\r\n })).reduce((accumulator, current) => accumulator.concat(current), [])\r\n\r\nexport const makeLaneFeatures = (selectedPartIndex, parts) => parts\r\n .filter(part => part.candidateLanes.length)\r\n .reduce((features, part, i) => features.concat(seperateMultiLineFeatureToLineFeatures({\r\n geometry: parse(part.candidateLanes[part.selectedLane].lines),\r\n type: 'Feature',\r\n properties: {\r\n id: i,\r\n selected: i === selectedPartIndex,\r\n isGapLine: false /*! !(lineIndex % (gap + 1)) */\r\n }\r\n })), [])\r\n\r\nexport const makeSelectedCandidateLane = partEditBuffer => {\r\n if (partEditBuffer.candidateLanes.length) {\r\n const selectedCandidate = partEditBuffer.candidateLanes[partEditBuffer.selectedLane]\r\n const wkt = partEditBuffer.segmentationResult[selectedCandidate.ringIndex][selectedCandidate.segmentIndex].lineString\r\n\r\n return {\r\n geometry: parse(wkt),\r\n type: 'Feature',\r\n properties: {\r\n id: 'selectedCandidateLane',\r\n isSegment: true\r\n }\r\n }\r\n } else {\r\n return null\r\n }\r\n}\r\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 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 isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\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","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\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","'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;","var baseForOwn = require('./_baseForOwn'),\n createBaseEach = require('./_createBaseEach');\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nmodule.exports = baseEach;\n","import {mapValues} from 'lodash'\r\n\r\nexport const commonParameters = () => ({\r\n // application map data\r\n name: '',\r\n productId: null,\r\n unit: null,\r\n // metadata\r\n zoneMapId: null,\r\n cultivationId: null,\r\n // algorithm data\r\n algorithm: null,\r\n applicationValues: null // {[zoneId]: value}\r\n})\r\n\r\nexport const validUnits = {\r\n wimexMaize: ['K/m²', 'K/ha'],\r\n wimexWinterWheat: ['kg/ha'],\r\n wimexUnderRootFertilization: ['kg/ha', 'l/ha']\r\n}\r\n\r\nexport const convertApplicationValues = ({applicationValues, unit}) => {\r\n if (unit === 'K/ha') return mapValues(applicationValues, x => x * 10000)\r\n\r\n return applicationValues\r\n}\r\n\r\nconst parameters = {\r\n wimexMaize: () => ({\r\n unit: 'K/m²',\r\n estimatedPrecipitation: null,\r\n minSoilMoisture: null,\r\n maxSoilMoisture: null,\r\n additionalZoneValues: null // {[zoneId]: {pwc: value, acreRatio: value}}\r\n }),\r\n wimexWinterWheat: () => ({\r\n unit: 'kg/ha',\r\n type: 1,\r\n dateOfSeed: 1,\r\n thousandKernelWeight: null,\r\n germinationCapacity: null,\r\n germination: null,\r\n additionalZoneValues: null // {[zoneId]: {pwc: value, acreRatio: value, waterAvailability: value}}\r\n }),\r\n wimexUnderRootFertilization: () => ({\r\n unit: 'kg/ha',\r\n temperature: null\r\n })\r\n}\r\n\r\nexport const makeTemplate = algorithm => parameters[algorithm]()\r\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","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 nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\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 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 translate from 'src/js/i18n/translate'\r\nimport {toMixtureName} from '../cultivation-planning/helpers'\r\n\r\nexport function cultivationToColor (cultivation) {\r\n let color\r\n switch (cultivation.type) {\r\n case 'main':\r\n case 'secondary':\r\n color = cultivation.color\r\n break\r\n case 'eco': {\r\n switch (cultivation.ecoTypeId) {\r\n case 'Brache': {\r\n color = '#4a91b1'\r\n break\r\n }\r\n default: {\r\n color = '#6c9db3'\r\n break\r\n }\r\n }\r\n break\r\n }\r\n case 'catch': {\r\n color = '#302f69'\r\n break\r\n }\r\n default: {\r\n color = '#ff0000'\r\n break\r\n }\r\n }\r\n return color || '#3b3b3b'\r\n}\r\n\r\nexport function cultivationToName (cultivation) {\r\n switch (cultivation.type) {\r\n case 'main':\r\n case 'secondary': {\r\n if (!cultivation.cropUsageId) {\r\n console.error(`cropUsageId for cultivation with id ${cultivation.id} is null`)\r\n }\r\n return translate(`masterData.crops.usage.${cultivation.cropUsageId}_name`)\r\n }\r\n case 'catch': {\r\n return cultivation.mixtureComponents\r\n ? toMixtureName(cultivation.mixtureComponents)\r\n : translate('Areas.FieldRecordSystem.SR_FieldRecordSystem.CatchCrop')\r\n }\r\n case 'eco':\r\n return translate(`Areas.FieldRecordSystem.SR_FieldRecordSystem.EcoTypes_${cultivation.ecoTypeId}`)\r\n default:\r\n throw new Error(translate('Areas.FieldRecordSystem.SR_FieldRecordSystem.InvalidCultivationType').concat(`: ${cultivation.type}`))\r\n }\r\n}\r\n\r\nexport function cultivationTypeToShortcut (cultivation) {\r\n return translate(`Areas.FieldRecordSystem.SR_FieldRecordSystem.CultivationType_${cultivation.type}_shortcut`)\r\n}\r\n","var arrayAggregator = require('./_arrayAggregator'),\n baseAggregator = require('./_baseAggregator'),\n baseIteratee = require('./_baseIteratee'),\n isArray = require('./isArray');\n\n/**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\nfunction createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\n };\n}\n\nmodule.exports = createAggregator;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","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","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 * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\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","const classificationsPh = [\r\n {\r\n soilTypes: ['S'],\r\n ranges: {\r\n A: {min: 0.1, max: 4.2},\r\n B: {min: 4.3, max: 4.7},\r\n C: {min: 4.8, max: 5.1},\r\n D: {min: 5.2, max: 5.4},\r\n E: {min: 5.5, max: 6.2},\r\n F: {min: 6.3, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['lS', 'sU'],\r\n ranges: {\r\n A: {min: 0.1, max: 4.3},\r\n B: {min: 4.4, max: 4.8},\r\n C: {min: 4.9, max: 5.3},\r\n D: {min: 5.4, max: 5.7},\r\n E: {min: 5.8, max: 6.5},\r\n F: {min: 6.6, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['ssL', 'lU'],\r\n ranges: {\r\n A: {min: 0.1, max: 4.5},\r\n B: {min: 4.6, max: 5.0},\r\n C: {min: 5.1, max: 5.5},\r\n D: {min: 5.6, max: 6.0},\r\n E: {min: 6.1, max: 6.8},\r\n F: {min: 6.9, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0.1, max: 4.6},\r\n B: {min: 4.7, max: 5.2},\r\n C: {min: 5.3, max: 5.7},\r\n D: {min: 5.8, max: 6.2},\r\n E: {min: 6.3, max: 7.1},\r\n F: {min: 7.2, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T'],\r\n ranges: {\r\n A: {min: 0.1, max: 4.7},\r\n B: {min: 4.8, max: 5.3},\r\n C: {min: 5.4, max: 5.8},\r\n D: {min: 5.9, max: 6.3},\r\n E: {min: 6.4, max: 7.2},\r\n F: {min: 7.3, max: 9999}\r\n }\r\n }\r\n]\r\n\r\nconst classificationsPKMg = {\r\n phosphorus: {\r\n arable: [\r\n {\r\n soilTypes: ['S', 'lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 9},\r\n C: {min: 10, max: 18},\r\n D: {min: 19, max: 32},\r\n E: {min: 33, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T', 'flat S'],\r\n ranges: {\r\n A: {min: 0, max: 5},\r\n B: {min: 6, max: 13},\r\n C: {min: 14, max: 24},\r\n D: {min: 25, max: 38},\r\n E: {min: 39, max: 9999}\r\n }\r\n }\r\n ],\r\n grass: [\r\n {\r\n soilTypes: ['S', 'lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 9},\r\n C: {min: 10, max: 18},\r\n D: {min: 19, max: 32},\r\n E: {min: 33, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T', 'flat S'],\r\n ranges: {\r\n A: {min: 0, max: 5},\r\n B: {min: 6, max: 13},\r\n C: {min: 14, max: 24},\r\n D: {min: 25, max: 38},\r\n E: {min: 39, max: 9999}\r\n }\r\n }\r\n ]\r\n },\r\n potassium: {\r\n arable: [\r\n {\r\n soilTypes: ['S'],\r\n ranges: {\r\n A: {min: 0, max: 2},\r\n B: {min: 3, max: 5},\r\n C: {min: 6, max: 12},\r\n D: {min: 13, max: 19},\r\n E: {min: 20, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 9},\r\n C: {min: 10, max: 18},\r\n D: {min: 19, max: 32},\r\n E: {min: 33, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T'],\r\n ranges: {\r\n A: {min: 0, max: 5},\r\n B: {min: 6, max: 13},\r\n C: {min: 14, max: 24},\r\n D: {min: 25, max: 38},\r\n E: {min: 39, max: 9999}\r\n }\r\n }\r\n ],\r\n grass: [\r\n {\r\n soilTypes: ['S'],\r\n ranges: {\r\n A: {min: 0, max: 2},\r\n B: {min: 3, max: 5},\r\n C: {min: 6, max: 12},\r\n D: {min: 13, max: 19},\r\n E: {min: 20, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 9},\r\n C: {min: 10, max: 18},\r\n D: {min: 19, max: 32},\r\n E: {min: 33, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T'],\r\n ranges: {\r\n A: {min: 0, max: 5},\r\n B: {min: 6, max: 13},\r\n C: {min: 14, max: 24},\r\n D: {min: 25, max: 38},\r\n E: {min: 39, max: 9999}\r\n }\r\n }\r\n ]\r\n },\r\n magnesium: {\r\n arable: [\r\n {\r\n soilTypes: ['S', 'lS', 'sU'],\r\n ranges: {\r\n A: {min: 0, max: 1},\r\n B: {min: 2, max: 2},\r\n C: {min: 3, max: 4},\r\n D: {min: 5, max: 7},\r\n E: {min: 8, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['ssL', 'lU', 'sL', 'uL', 'L'],\r\n ranges: {\r\n A: {min: 0, max: 2},\r\n B: {min: 3, max: 3},\r\n C: {min: 4, max: 6},\r\n D: {min: 7, max: 10},\r\n E: {min: 11, max: 9999}\r\n }\r\n },\r\n {\r\n soilTypes: ['utL', 'tL', 'T'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 5},\r\n C: {min: 6, max: 9},\r\n D: {min: 10, max: 14},\r\n E: {min: 15, max: 9999}\r\n }\r\n }\r\n ],\r\n grass: [\r\n {\r\n soilTypes: ['S', 'lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L', 'utL', 'tL', 'T', 'flat S'],\r\n ranges: {\r\n A: {min: 0, max: 3},\r\n B: {min: 4, max: 7},\r\n C: {min: 8, max: 12},\r\n D: {min: 13, max: 18},\r\n E: {min: 19, max: 9999}\r\n }\r\n }\r\n ]\r\n }\r\n}\r\n\r\nconst validCalculationSubTypes = ['S', 'lS', 'sU', 'ssL', 'lU', 'sL', 'uL', 'L', 'utL', 'tL', 'T', 'flat S']\r\n\r\nexport const isCalculationPossible = soilSubTypeId => {\r\n return validCalculationSubTypes.includes(soilSubTypeMap(soilSubTypeId))\r\n}\r\n\r\nconst soilSubTypeMap = (soilSubType) => {\r\n // TODO add correct mapping\r\n // Sand\r\n if (soilSubType === 'Ss') return 'S'\r\n if (soilSubType === 'Su2') return 'S'\r\n if (soilSubType === 'Sl2') return 'lS'\r\n if (soilSubType === \"l'S\") return 'lS'\r\n if (soilSubType === 'Sl3') return 'lS'\r\n if (soilSubType === 'St2') return 'lS'\r\n if (soilSubType === 'Su4') return 'lS'\r\n if (soilSubType === 'Slu') return 'ssL'\r\n if (soilSubType === 'Sl4') return 'ssL'\r\n if (soilSubType === 'llS') return 'ssL'\r\n if (soilSubType === 'St3') return 'sL'\r\n\r\n // Lehm\r\n if (soilSubType === 'Ls2') return 'sL'\r\n if (soilSubType === 'Ls3') return 'sL'\r\n if (soilSubType === 'Ls4') return 'sL'\r\n if (soilSubType === 'ssL') return 'sL'\r\n if (soilSubType === 'Lts') return 'sL'\r\n if (soilSubType === 'Lu') return 'sL'\r\n if (soilSubType === 'Lt3') return 'utL'\r\n\r\n // Ton\r\n if (soilSubType === 'Tt') return 'T'\r\n if (soilSubType === 'Tl') return 'utL'\r\n if (soilSubType === 'Tu3') return 'utL'\r\n if (soilSubType === 'Tu4') return 'utL'\r\n if (soilSubType === 'uuT') return 'utL'\r\n if (soilSubType === 'Tu2') return 'utL'\r\n if (soilSubType === 'Ts2') return 'utL'\r\n if (soilSubType === 'Ts3') return 'utL'\r\n if (soilSubType === 'Ts4') return 'sL'\r\n\r\n // Schluff\r\n if (soilSubType === 'U') return 'lS'\r\n if (soilSubType === 'UU') return 'lS'\r\n if (soilSubType === 'sU') return 'lS'\r\n if (soilSubType === 'Us') return 'lS'\r\n if (soilSubType === 'Ut2') return 'ssL'\r\n if (soilSubType === 'Ut3') return 'sL'\r\n if (soilSubType === 'Uls') return 'ssL'\r\n if (soilSubType === 'Ut4') return 'sL'\r\n if (soilSubType === 'ttU') return 'sL'\r\n\r\n return soilSubType\r\n}\r\n\r\nconst bySoilType = soilSubTypeId => {\r\n const mappedSoilSubType = soilSubTypeMap(soilSubTypeId)\r\n\r\n return classification => classification.soilTypes.some(x => x === mappedSoilSubType)\r\n}\r\n\r\nconst isWithinRange = (ranges, key, value) => ranges[key].min <= value && ranges[key].max >= value\r\n\r\nconst computeClassificationPKMg = ({nutrient, usage, soilSubTypeId, measurement}) => {\r\n if (!measurement || !usage || !soilSubTypeId) {\r\n return null\r\n }\r\n\r\n if (!classificationsPKMg[nutrient][usage]) return null\r\n\r\n const {ranges} = classificationsPKMg[nutrient][usage].find(bySoilType(soilSubTypeId))\r\n return Object.keys(ranges).find(x => isWithinRange(ranges, x, Math.round(measurement))) // TODO find out why rounded\r\n}\r\n\r\nconst computeClassificationPh = ({measurement, soilSubTypeId}) => {\r\n if (!measurement || !soilSubTypeId) {\r\n return null\r\n }\r\n const {ranges} = classificationsPh.find(bySoilType(soilSubTypeId))\r\n return Object.keys(ranges).find(x => isWithinRange(ranges, x, Math.round(measurement * 10) / 10)) // TODO find out why rounded\r\n}\r\n\r\nexport {\r\n computeClassificationPKMg,\r\n computeClassificationPh\r\n}\r\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","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","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","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","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global.quickselect = factory());\n}(this, (function () { 'use strict';\n\nfunction quickselect(arr, k, left, right, compare) {\n quickselectStep(arr, k, left || 0, right || (arr.length - 1), compare || defaultCompare);\n}\n\nfunction quickselectStep(arr, k, left, right, compare) {\n\n while (right > left) {\n if (right - left > 600) {\n var n = right - left + 1;\n var m = k - left + 1;\n var z = Math.log(n);\n var s = 0.5 * Math.exp(2 * z / 3);\n var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselectStep(arr, k, newLeft, newRight, compare);\n }\n\n var t = arr[k];\n var i = left;\n var j = right;\n\n swap(arr, left, k);\n if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n while (i < j) {\n swap(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) i++;\n while (compare(arr[j], t) > 0) j--;\n }\n\n if (compare(arr[left], t) === 0) swap(arr, left, j);\n else {\n j++;\n swap(arr, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\nfunction swap(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nreturn quickselect;\n\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","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nmodule.exports = baseMatches;\n","module.exports.RADIUS = 6378137;\nmodule.exports.FLATTENING = 1/298.257223563;\nmodule.exports.POLAR_RADIUS = 6356752.3142;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\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 assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\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","var baseAssignValue = require('./_baseAssignValue'),\n createAggregator = require('./_createAggregator');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\nvar groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n});\n\nmodule.exports = groupBy;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\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 createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\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","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","export function partition (array, predicate) {\r\n const trueItems = []\r\n const falseItems = []\r\n for (const item of array) {\r\n (predicate(item) ? trueItems : falseItems).push(item)\r\n }\r\n return [trueItems, falseItems]\r\n}\r\n\r\nexport function zip (array1, array2) {\r\n if (array1.length !== array2.length) {\r\n throw new Error('cannot zip arrays of different lengths')\r\n }\r\n\r\n return array1.map((x, i) => [x, array2[i]])\r\n}\r\n\r\nexport function range (lengthOrStart, stop, step) {\r\n if (stop === undefined) {\r\n return new Array(lengthOrStart).fill(null).map((x, i) => i)\r\n }\r\n\r\n if (step === undefined) {\r\n return new Array(stop - lengthOrStart + 1).fill(null).map((x, i) => lengthOrStart + i)\r\n }\r\n\r\n const count = Math.floor((stop - lengthOrStart + 1) / step)\r\n\r\n return new Array(count).fill(null).map((x, i) => lengthOrStart + i * step)\r\n}\r\n","import {range} from '@helpers/arrays'\r\nimport {getZoneCount} from '@helpers/zone-map'\r\n\r\nexport const zoneMapHeterogenitySpread = {\r\n null: 0, // TODO maybe remove if server always returns enum member\r\n 'None': 0,\r\n 'Homogeneous': 0.1,\r\n 'SlightlyHeterogeneous': 0.15,\r\n 'Heterogenous': 0.2,\r\n 'IncreasinglyHeterogenous': 0.25,\r\n 'StronglyHeterogenous': 0.3\r\n}\r\n\r\nconst precision = 2\r\n\r\nexport const spreadByHeterogenity = (averageValue, zoneMap) => {\r\n if (!zoneMap || !zoneMap.zones || averageValue === null) return null\r\n\r\n const {heterogenity} = zoneMap\r\n\r\n const zoneCount = getZoneCount(zoneMap)\r\n\r\n const heterogenityStart = 1 + zoneMapHeterogenitySpread[heterogenity]\r\n const heterogenityStep = zoneCount > 1\r\n ? zoneMapHeterogenitySpread[heterogenity] * 2 / (zoneCount - 1)\r\n : 0\r\n\r\n const zoneFactors = range(zoneCount).map(i => heterogenityStart - i * heterogenityStep)\r\n\r\n const round = x => Math.round(Math.pow(10, precision) * x) / Math.pow(10, precision)\r\n\r\n const zoneAmounts = {}\r\n\r\n for (const zone of zoneMap.zones) {\r\n zoneAmounts[zone.id] = round(zoneFactors[zone.number - 1] * averageValue)\r\n }\r\n\r\n return zoneAmounts\r\n}\r\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\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","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 baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\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 defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\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;iv 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","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\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 isArrayLike = require('./isArrayLike');\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nmodule.exports = createBaseEach;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\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 * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nmodule.exports = baseIsMatch;\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","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","import {keyBy} from 'lodash'\r\n\r\n// cultivation getters\r\nexport function cultivationData (state) {\r\n if (!state.cultivations.length) return []\r\n return state.cultivations.map(cultivation => cultivation.properties)\r\n}\r\n\r\nexport function cultivationDataLookup (state, getters) {\r\n if (!getters.cultivationData.length) return {}\r\n return keyBy(getters.cultivationData, 'id')\r\n}\r\n\r\nexport function cultivationFeatureLookup (state) {\r\n if (!state.cultivations.length) return {}\r\n return keyBy(state.cultivations, 'properties.id')\r\n}\r\n\r\nexport function visibleCultivationFeatures (state) {\r\n return state.cultivations.filter(feature => state.visible.includes(feature.properties.id))\r\n}\r\n\r\nexport function visibleCultivationData (state) {\r\n if (!state.cultivations.length) return []\r\n return state.cultivations.filter(feature => state.visible.includes(feature.properties.id)).map(cultivation => cultivation.properties)\r\n}\r\n\r\nexport function selectedCultivationData (state, getters) {\r\n if (!state.selected.length) return getters.cultivationData\r\n return state.selected.map(cultivationId => getters.cultivationDataLookup[cultivationId])\r\n}\r\n// field getters\r\nexport function fieldDataLookup (state) {\r\n if (!state.fields.length) return {}\r\n\r\n const properties = state.fields.map(field => field.properties)\r\n return keyBy(properties, 'id')\r\n}\r\n\r\nexport function fieldFeatureLookup (state) {\r\n if (!state.fields.length) return {}\r\n return keyBy(state.fields, 'properties.id')\r\n}\r\n\r\nexport function selectedFieldFeatures (state, getters) {\r\n if (!state.fields.length) return []\r\n return getters.selectedFieldIds.map(id => getters.fieldFeatureLookup[id])\r\n}\r\n\r\nexport function selectedFieldIds (state, getters) {\r\n return state.selected.map(cultivationId => getters.cultivationDataLookup[cultivationId])\r\n .map(cultivation => cultivation.fieldIds)\r\n .reduce((acc, curr) => acc.concat(curr), [])\r\n}\r\n","import {can} from '@helpers/permissions'\r\nimport {smarterGet, smarterDelete} from '@helpers/vuex/data-loading'\r\n\r\nexport function loadPrerequisiteData ({dispatch, rootState}) {\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return Promise.all([\r\n dispatch('fieldRecordSystem/machines/loadMachines', null, {root: true}),\r\n dispatch('fieldRecordSystem/persons/loadPersons', null, {root: true}),\r\n dispatch('loadCultivations')\r\n ])\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport function loadCultivations ({commit, rootState}) {\r\n return smarterGet([\r\n '/api/v2/{harvestYear}/org/{orgUnitId}/cultivations'\r\n ], {\r\n id: 'orgUnit.cultivations.loadCultivations',\r\n inputs: {\r\n orgUnitId: () => rootState.fieldRecordSystem.navigation.location.orgUnitId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n sharedCache: true,\r\n onResult ([data]) {\r\n commit('removeUnknownSelected', data.cultivations)\r\n commit('initializeCultivations', data.cultivations)\r\n commit('setFields', data.fields)\r\n commit('setOrgUnitName', data.orgUnitName)\r\n }\r\n })\r\n}\r\n\r\nexport function deleteCultivation ({commit, dispatch}, cultivationId) {\r\n return smarterDelete('/api/v2/cultivations/{cultivationId}', {\r\n id: 'orgUnit.cultivationsV2.delete',\r\n inputs: {\r\n cultivationId: () => cultivationId\r\n }\r\n }).then(() => {\r\n commit('toggleCultivation', cultivationId)\r\n dispatch('loadPrerequisiteData')\r\n })\r\n}\r\n\r\nexport function acceptAndToggleFilterRule ({commit}, rule) {\r\n let ruleAccepted = true\r\n if (!rule.hasOwnProperty('property')) {\r\n console.error('Rule property \\'property\\' is missing')\r\n ruleAccepted = false\r\n }\r\n if (!rule.hasOwnProperty('filter')) {\r\n console.error('Rule property \\'filter\\' is missing')\r\n ruleAccepted = false\r\n }\r\n if (!rule.hasOwnProperty('operation')) {\r\n console.error('Rule property \\'operation\\' is missing')\r\n ruleAccepted = false\r\n }\r\n\r\n if (ruleAccepted) {\r\n commit('toggleRule', rule)\r\n }\r\n}\r\n\r\nexport function toggleCultivation ({state, commit, dispatch}, cultivationId) {\r\n commit('toggleCultivation', cultivationId)\r\n const features = state.cultivations.filter(feature => state.selected.includes(feature.properties.id))\r\n return dispatch('fieldRecordSystem/map/focus', features, {root: true})\r\n}\r\n","import {defaults} from './index'\r\nimport {cultivationToColor, cultivationToName, cultivationTypeToShortcut} from '@frs/components/cultivation-overview/helpers'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst mutations = {\r\n ...makeSetters([\r\n 'cultivations',\r\n 'fields',\r\n 'orgUnitName',\r\n 'selected'\r\n ]),\r\n removeUnknownSelected (state, cultivations) {\r\n const cultivationIds = cultivations.map(x => x.properties.id)\r\n const ids = state.selected.filter(id => cultivationIds.includes(id))\r\n state.selected = ids\r\n },\r\n initializeCultivations (state, cultivations) {\r\n cultivations.forEach(cultivation => {\r\n cultivation.properties.color = cultivationToColor(cultivation.properties)\r\n cultivation.properties.label = cultivationToName(cultivation.properties)\r\n cultivation.properties.typeShortcut = cultivationTypeToShortcut(cultivation.properties)\r\n })\r\n state.cultivations = cultivations\r\n },\r\n toggleCultivation (state, cultivationId) {\r\n const ids = [...state.selected]\r\n if (ids.includes(cultivationId)) {\r\n const index = ids.indexOf(cultivationId)\r\n ids.splice(index, 1)\r\n } else {\r\n ids.push(cultivationId)\r\n }\r\n state.selected = ids\r\n },\r\n toggleRule (state, rule) {\r\n const clone = [...state.filterRules]\r\n const index = clone.findIndex(ruleElement => (ruleElement.property === rule.property && ruleElement.filter === rule.filter))\r\n\r\n if (index !== -1) {\r\n clone.splice(index, 1)\r\n } else {\r\n clone.push(rule)\r\n }\r\n state.filterRules = clone\r\n },\r\n setVisibleCultivations (state, visibleCultivation) {\r\n state.visible = visibleCultivation.map(x => x.id)\r\n },\r\n clearSelected (state) {\r\n state.selected = []\r\n },\r\n clearFilter (state) {\r\n state.filterRules = []\r\n },\r\n deselectFilterType (state, type) {\r\n state.filterRules = state.filterRules.filter(x => x.property !== type)\r\n },\r\n reset (state) {\r\n var reset = {...defaults(), selected: state.selected}\r\n Object.assign(state, reset)\r\n }\r\n}\r\n\r\nexport default mutations\r\n","import * as getters from './getters'\r\nimport * as actions from './actions'\r\nimport mutations from './mutations'\r\n\r\nexport const defaults = () => ({\r\n orgUnitName: null,\r\n cultivations: [],\r\n fields: [],\r\n selected: [],\r\n visible: [],\r\n filterRules: []\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n getters,\r\n actions,\r\n mutations\r\n}\r\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","\n\t\t\t\tvar addMethods = require(\"../../../../../../../node_modules/workerize-loader/dist/rpc-wrapper.js\")\n\t\t\t\tvar methods = [\"processFieldWkts\"]\n\t\t\t\tmodule.exports = function() {\n\t\t\t\t\tvar w = new Worker(URL.createObjectURL(new Blob([\"(function(t){var e={};function n(r){if(e[r])return e[r].exports;var i=e[r]={i:r,l:!1,exports:{}};return t[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){\\\"undefined\\\"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:\\\"Module\\\"}),Object.defineProperty(t,\\\"__esModule\\\",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&\\\"object\\\"===typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,\\\"default\\\",{enumerable:!0,value:t}),2&e&&\\\"string\\\"!=typeof t)for(var i in t)n.d(r,i,function(e){return t[e]}.bind(null,i));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t[\\\"default\\\"]}:function(){return t};return n.d(e,\\\"a\\\",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p=\\\"/dist/\\\",n(n.s=\\\"938a\\\")})({\\\"0000\\\":function(t,e,n){\\\"use strict\\\";t.exports=f;var r=n(\\\"92ba\\\"),i=n(\\\"24ad\\\").compareCells;function o(t,e,n){this.vertices=t,this.adjacent=e,this.boundary=n,this.lastVisited=-1}function s(t,e,n){this.vertices=t,this.cell=e,this.index=n}function a(t,e){return i(t.vertices,e.vertices)}function u(t){for(var e=[\\\"function orient(){var tuple=this.tuple;return test(\\\"],n=0;n<=t;++n)n>0&&e.push(\\\",\\\"),e.push(\\\"tuple[\\\",n,\\\"]\\\");e.push(\\\")}return orient\\\");var i=new Function(\\\"test\\\",e.join(\\\"\\\")),o=r[t+1];return o||(o=r),i(o)}o.prototype.flip=function(){var t=this.vertices[0];this.vertices[0]=this.vertices[1],this.vertices[1]=t;var e=this.adjacent[0];this.adjacent[0]=this.adjacent[1],this.adjacent[1]=e};var l=[];function c(t,e,n){this.dimension=t,this.vertices=e,this.simplices=n,this.interior=n.filter(function(t){return!t.boundary}),this.tuple=new Array(t+1);for(var r=0;r<=t;++r)this.tuple[r]=this.vertices[r];var i=l[t];i||(i=l[t]=u(t)),this.orient=i}var h=c.prototype;function f(t,e){var n=t.length;if(0===n)throw new Error(\\\"Must have at least d+1 points\\\");var i=t[0].length;if(n<=i)throw new Error(\\\"Must input at least d+1 points\\\");var s=t.slice(0,i+1),a=r.apply(void 0,s);if(0===a)throw new Error(\\\"Input not in general position\\\");for(var u=new Array(i+1),l=0;l<=i;++l)u[l]=l;a<0&&(u[0]=1,u[1]=0);var h=new o(u,new Array(i+1),!1),f=h.adjacent,g=new Array(i+2);for(l=0;l<=i;++l){for(var d=u.slice(),p=0;p<=i;++p)p===l&&(d[p]=-1);var v=d[0];d[0]=d[1],d[1]=v;var y=new o(d,new Array(i+1),!0);f[l]=y,g[l]=y}g[i+1]=h;for(l=0;l<=i;++l){d=f[l].vertices;var m=f[l].adjacent;for(p=0;p<=i;++p){var x=d[p];if(x<0)m[p]=h;else for(var E=0;E<=i;++E)f[E].vertices.indexOf(x)<0&&(m[p]=f[E])}}var w=new c(i,s,g),b=!!e;for(l=i+1;l0){t=s.pop();t.vertices;for(var a=t.adjacent,u=0;u<=n;++u){var l=a[u];if(l.boundary&&!(l.lastVisited<=-r)){for(var c=l.vertices,h=0;h<=n;++h){var f=c[h];i[h]=f<0?e:o[f]}var g=this.orient();if(g>0)return l;l.lastVisited=-r,0===g&&s.push(l)}}}return null},h.walk=function(t,e){var n=this.vertices.length-1,r=this.dimension,i=this.vertices,o=this.tuple,s=e?this.interior.length*Math.random()|0:this.interior.length-1,a=this.interior[s];t:while(!a.boundary){for(var u=a.vertices,l=a.adjacent,c=0;c<=r;++c)o[c]=i[u[c]];a.lastVisited=n;for(c=0;c<=r;++c){var h=l[c];if(!(h.lastVisited>=n)){var f=o[c];o[c]=t;var g=this.orient();if(o[c]=f,g<0){a=h;continue t}h.boundary?h.lastVisited=-n:h.lastVisited=n}}return}return a},h.addPeaks=function(t,e){var n=this.vertices.length-1,r=this.dimension,i=this.vertices,u=this.tuple,l=this.interior,c=this.simplices,h=[e];e.lastVisited=n,e.vertices[e.vertices.indexOf(-1)]=n,e.boundary=!1,l.push(e);var f=[];while(h.length>0){e=h.pop();var g=e.vertices,d=e.adjacent,p=g.indexOf(n);if(!(p<0))for(var v=0;v<=r;++v)if(v!==p){var y=d[v];if(y.boundary&&!(y.lastVisited>=n)){var m=y.vertices;if(y.lastVisited!==-n){for(var x=0,E=0;E<=r;++E)m[E]<0?(x=E,u[E]=t):u[E]=i[m[E]];var w=this.orient();if(w>0){m[x]=n,y.boundary=!1,l.push(y),h.push(y),y.lastVisited=n;continue}y.lastVisited=-n}var b=y.adjacent,I=g.slice(),N=d.slice(),C=new o(I,N,!0);c.push(C);var S=b.indexOf(e);if(!(S<0)){b[S]=C,N[p]=y,I[v]=-1,N[v]=e,d[v]=C,C.flip();for(E=0;E<=r;++E){var M=I[E];if(!(M<0||M===n)){for(var _=new Array(r-1),L=0,P=0;P<=r;++P){var R=I[P];R<0||P===E||(_[L++]=R)}f.push(new s(_,C,E))}}}}}}f.sort(a);for(v=0;v+1=0?s[u++]=a[c]:l=1&c;if(l===(1&t)){var h=s[0];s[0]=s[1],s[1]=h}e.push(s)}}return e}},\\\"00a2\\\":function(t,e){function n(t){if(!t)throw new Error(\\\"obj is required\\\");var e=r(t);if(e.length>1&&\\\"number\\\"===typeof e[0]&&\\\"number\\\"===typeof e[1])return e;throw new Error(\\\"Coordinate is not a valid Point\\\")}function r(t){if(!t)throw new Error(\\\"obj is required\\\");var e;if(t.length?e=t:t.coordinates?e=t.coordinates:t.geometry&&t.geometry.coordinates&&(e=t.geometry.coordinates),e)return i(e),e;throw new Error(\\\"No valid coordinates\\\")}function i(t){if(t.length>1&&\\\"number\\\"===typeof t[0]&&\\\"number\\\"===typeof t[1])return!0;if(Array.isArray(t[0])&&t[0].length)return i(t[0]);throw new Error(\\\"coordinates must only contain numbers\\\")}function o(t,e,n){if(!e||!n)throw new Error(\\\"type and name required\\\");if(!t||t.type!==e)throw new Error(\\\"Invalid input to \\\"+n+\\\": must be a \\\"+e+\\\", given \\\"+t.type)}function s(t,e,n){if(!t)throw new Error(\\\"No feature passed\\\");if(!n)throw new Error(\\\".featureOf() requires a name\\\");if(!t||\\\"Feature\\\"!==t.type||!t.geometry)throw new Error(\\\"Invalid input to \\\"+n+\\\", Feature with geometry required\\\");if(!t.geometry||t.geometry.type!==e)throw new Error(\\\"Invalid input to \\\"+n+\\\": must be a \\\"+e+\\\", given \\\"+t.geometry.type)}function a(t,e,n){if(!t)throw new Error(\\\"No featureCollection passed\\\");if(!n)throw new Error(\\\".collectionOf() requires a name\\\");if(!t||\\\"FeatureCollection\\\"!==t.type)throw new Error(\\\"Invalid input to \\\"+n+\\\", FeatureCollection required\\\");for(var r=0;r=t.minX&&e.maxY>=t.minY}function y(t){return{children:t,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function m(t,e,n,i,o){var s,a=[e,n];while(a.length)n=a.pop(),e=a.pop(),n-e<=i||(s=e+Math.ceil((n-e)/i/2)*i,r(t,s,e,n,o),a.push(e,s,s,n))}i.prototype={all:function(){return this._all(this.data,[])},search:function(t){var e=this.data,n=[],r=this.toBBox;if(!v(t,e))return n;var i,o,s,a,u=[];while(e){for(i=0,o=e.children.length;i=0){if(!(o[e].children.length>this._maxEntries))break;this._split(o,e),e--}this._adjustParentBBoxes(i,o,e)},_split:function(t,e){var n=t[e],r=n.children.length,i=this._minEntries;this._chooseSplitAxis(n,i,r);var o=this._chooseSplitIndex(n,i,r),a=y(n.children.splice(o,n.children.length-o));a.height=n.height,a.leaf=n.leaf,s(n,this.toBBox),s(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(n,a)},_splitRoot:function(t,e){this.data=y([t,e]),this.data.height=t.height+1,this.data.leaf=!1,s(this.data,this.toBBox)},_chooseSplitIndex:function(t,e,n){var r,i,o,s,u,l,c,f;for(l=c=1/0,r=e;r<=n-e;r++)i=a(t,0,r,this.toBBox),o=a(t,r,n,this.toBBox),s=d(i,o),u=h(i)+h(o),s=e;i--)o=t.children[i],u(c,t.leaf?s(o):o),h+=f(c);return h},_adjustParentBBoxes:function(t,e,n){for(var r=n;r>=0;r--)u(e[r],t)},_condense:function(t){for(var e,n=t.length-1;n>=0;n--)0===t[n].children.length?n>0?(e=t[n-1].children,e.splice(e.indexOf(t[n]),1)):this.clear():s(t[n],this.toBBox)},_initFormat:function(t){var e=[\\\"return a\\\",\\\" - b\\\",\\\";\\\"];this.compareMinX=new Function(\\\"a\\\",\\\"b\\\",e.join(t[0])),this.compareMinY=new Function(\\\"a\\\",\\\"b\\\",e.join(t[1])),this.toBBox=new Function(\\\"a\\\",\\\"return {minX: a\\\"+t[0]+\\\", minY: a\\\"+t[1]+\\\", maxX: a\\\"+t[2]+\\\", maxY: a\\\"+t[3]+\\\"};\\\")}}},\\\"0364\\\":function(t,e){function n(t,e,r){if(null!==t){var i,o,s,a,u,l,c,h,f,g,d=0,p=0,v=t.type,y=\\\"FeatureCollection\\\"===v,m=\\\"Feature\\\"===v,x=y?t.features.length:1;for(i=0;i=0;--o){var s=n[o],a=s.symetric,u=void 0,l=void 0;s.label===e&&(u=s),a.label===e&&(l=a),u&&l&&(l&&(i=l),u&&(i&&(i.next=u,i=void 0),r||(r=u)))}i&&(i.next=r)}},{key:\\\"_findLabeledEdgeRings\\\",value:function(){var t=[],e=0;return this.edges.forEach(function(n){if(!(n.label>=0)){t.push(n);var r=n;do{r.label=e,r=r.next}while(!n.isEqual(r));e++}}),t}},{key:\\\"getEdgeRings\\\",value:function(){var t=this;this._computeNextCWEdges(),this.edges.forEach(function(t){t.label=void 0}),this._findLabeledEdgeRings().forEach(function(e){t._findIntersectionNodes(e).forEach(function(n){t._computeNextCCWEdges(n,e.label)})});var e=[];return this.edges.forEach(function(n){n.ring||e.push(t._findEdgeRing(n))}),e}},{key:\\\"_findIntersectionNodes\\\",value:function(t){var e=[],n=t,r=function(){var r=0;n.from.getOuterEdges().forEach(function(e){e.label===t.label&&++r}),r>1&&e.push(n.from),n=n.next};do{r()}while(!t.isEqual(n));return e}},{key:\\\"_findEdgeRing\\\",value:function(t){var e=t,n=new a;do{n.push(e),e.ring=n,e=e.next}while(!t.isEqual(e));return n}},{key:\\\"removeNode\\\",value:function(t){var e=this;t.getOuterEdges().forEach(function(t){return e.removeEdge(t)}),t.innerEdges.forEach(function(t){return e.removeEdge(t)}),delete this.nodes[t.id]}},{key:\\\"removeEdge\\\",value:function(t){this.edges=this.edges.filter(function(e){return!e.isEqual(t)}),t.deleteEdge()}}]),t}();t.exports=d},\\\"050d\\\":function(t,e,n){var r=n(\\\"7fae\\\"),i=function(t){this.precision=t&&t.precision?t.precision:17,this.direction=!(!t||!t.direction)&&t.direction,this.pseudoNode=!(!t||!t.pseudoNode)&&t.pseudoNode,this.objectComparator=t&&t.objectComparator?t.objectComparator:a};function o(t){return t.coordinates.map(function(e){return{type:t.type.replace(\\\"Multi\\\",\\\"\\\"),coordinates:e}})}function s(t,e){return t.hasOwnProperty(\\\"coordinates\\\")?t.coordinates.length===e.coordinates.length:t.length===e.length}function a(t,e){return r(t,e,{strict:!0})}i.prototype.compare=function(t,e){if(t.type!==e.type||!s(t,e))return!1;switch(t.type){case\\\"Point\\\":return this.compareCoord(t.coordinates,e.coordinates);case\\\"LineString\\\":return this.compareLine(t.coordinates,e.coordinates,0,!1);case\\\"Polygon\\\":return this.comparePolygon(t,e);case\\\"Feature\\\":return this.compareFeature(t,e);default:if(0===t.type.indexOf(\\\"Multi\\\")){var n=this,r=o(t),i=o(e);return r.every(function(t){return this.some(function(e){return n.compare(t,e)})},i)}}return!1},i.prototype.compareCoord=function(t,e){if(t.length!==e.length)return!1;for(var n=0;n=0&&(n=[].concat(t.slice(r,t.length),t.slice(1,r+1))),n},i.prototype.comparePath=function(t,e){var n=this;return t.every(function(t,e){return n.compareCoord(t,this[e])},e)},i.prototype.comparePolygon=function(t,e){if(this.compareLine(t.coordinates[0],e.coordinates[0],1,!0)){var n=t.coordinates.slice(1,t.coordinates.length),r=e.coordinates.slice(1,e.coordinates.length),i=this;return n.every(function(t){return this.some(function(e){return i.compareLine(t,e,1,!0)})},r)}return!1},i.prototype.compareFeature=function(t,e){return!(t.id!==e.id||!this.objectComparator(t.properties,e.properties)||!this.compareBBox(t,e))&&this.compare(t.geometry,e.geometry)},i.prototype.compareBBox=function(t,e){return!!(!t.bbox&&!e.bbox||t.bbox&&e.bbox&&this.compareCoord(t.bbox,e.bbox))},i.prototype.removePseudo=function(t){return t},t.exports=i},\\\"0a06\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\"),i=n(\\\"30b5\\\"),o=n(\\\"f6b4\\\"),s=n(\\\"5270\\\"),a=n(\\\"4a7b\\\");function u(t){this.defaults=t,this.interceptors={request:new o,response:new o}}u.prototype.request=function(t){\\\"string\\\"===typeof t?(t=arguments[1]||{},t.url=arguments[0]):t=t||{},t=a(this.defaults,t),t.method=t.method?t.method.toLowerCase():\\\"get\\\";var e=[s,void 0],n=Promise.resolve(t);this.interceptors.request.forEach(function(t){e.unshift(t.fulfilled,t.rejected)}),this.interceptors.response.forEach(function(t){e.push(t.fulfilled,t.rejected)});while(e.length)n=n.then(e.shift(),e.shift());return n},u.prototype.getUri=function(t){return t=a(this.defaults,t),i(t.url,t.params,t.paramsSerializer).replace(/^\\\\?/,\\\"\\\")},r.forEach([\\\"delete\\\",\\\"get\\\",\\\"head\\\",\\\"options\\\"],function(t){u.prototype[t]=function(e,n){return this.request(r.merge(n||{},{method:t,url:e}))}}),r.forEach([\\\"post\\\",\\\"put\\\",\\\"patch\\\"],function(t){u.prototype[t]=function(e,n,i){return this.request(r.merge(i||{},{method:t,url:e,data:n}))}}),t.exports=u},\\\"0a0e\\\":function(t,e,n){\\\"use strict\\\";if(t.exports)var r=n(\\\"6359\\\");function i(t,e){if(!(this instanceof i))return new i(t,e);this.easting=Number(t),this.northing=Number(e)}i.latLonToOsGrid=function(t){if(!(t instanceof r))throw new TypeError(\\\"point is not LatLon object\\\");t.datum!=r.datum.OSGB36&&(t=t.convertDatum(r.datum.OSGB36));var e=t.lat.toRadians(),n=t.lon.toRadians(),o=6377563.396,s=6356256.909,a=.9996012717,u=49..toRadians(),l=(-2).toRadians(),c=-1e5,h=4e5,f=1-s*s/(o*o),g=(o-s)/(o+s),d=g*g,p=g*g*g,v=Math.cos(e),y=Math.sin(e),m=o*a/Math.sqrt(1-f*y*y),x=o*a*(1-f)/Math.pow(1-f*y*y,1.5),E=m/x-1,w=(1+g+5/4*d+5/4*p)*(e-u),b=(3*g+3*g*g+21/8*p)*Math.sin(e-u)*Math.cos(e+u),I=(15/8*d+15/8*p)*Math.sin(2*(e-u))*Math.cos(2*(e+u)),N=35/24*p*Math.sin(3*(e-u))*Math.cos(3*(e+u)),C=s*a*(w-b+I-N),S=v*v*v,M=S*v*v,_=Math.tan(e)*Math.tan(e),L=_*_,P=C+c,R=m/2*y*v,T=m/24*y*S*(5-_+9*E),O=m/720*y*M*(61-58*_+L),A=m*v,D=m/6*S*(m/x-_),F=m/120*M*(5-18*_+L+14*E-58*_*E),k=n-l,G=k*k,V=G*k,q=V*k,B=q*k,z=B*k,j=P+R*G+T*q+O*z,U=h+A*k+D*V+F*B;return j=Number(j.toFixed(3)),U=Number(U.toFixed(3)),new i(U,j)},i.osGridToLatLon=function(t,e){if(!(t instanceof i))throw new TypeError(\\\"gridref is not OsGridRef object\\\");void 0===e&&(e=r.datum.WGS84);var n=t.easting,o=t.northing,s=6377563.396,a=6356256.909,u=.9996012717,l=49..toRadians(),c=(-2).toRadians(),h=-1e5,f=4e5,g=1-a*a/(s*s),d=(s-a)/(s+a),p=d*d,v=d*d*d,y=l,m=0;do{y=(o-h-m)/(s*u)+y;var x=(1+d+5/4*p+5/4*v)*(y-l),E=(3*d+3*d*d+21/8*v)*Math.sin(y-l)*Math.cos(y+l),w=(15/8*p+15/8*v)*Math.sin(2*(y-l))*Math.cos(2*(y+l)),b=35/24*v*Math.sin(3*(y-l))*Math.cos(3*(y+l));m=a*u*(x-E+w-b)}while(o-h-m>=1e-5);var I=Math.cos(y),N=Math.sin(y),C=s*u/Math.sqrt(1-g*N*N),S=s*u*(1-g)/Math.pow(1-g*N*N,1.5),M=C/S-1,_=Math.tan(y),L=_*_,P=L*L,R=P*L,T=1/I,O=C*C*C,A=O*C*C,D=A*C*C,F=_/(2*S*C),k=_/(24*S*O)*(5+3*L+M-9*L*M),G=_/(720*S*A)*(61+90*L+45*P),V=T/C,q=T/(6*O)*(C/S+2*L),B=T/(120*A)*(5+28*L+24*P),z=T/(5040*D)*(61+662*L+1320*P+720*R),j=n-f,U=j*j,X=U*j,Y=U*U,W=X*U,H=Y*U,J=W*U;y=y-F*U+k*Y-G*H;var Z=c+V*j-q*X+B*W-z*J,K=new r(y.toDegrees(),Z.toDegrees(),r.datum.OSGB36);return e!=r.datum.OSGB36&&(K=K.convertDatum(e)),K},i.parse=function(t){t=String(t).trim();var e=t.match(/^(\\\\d+),\\\\s*(\\\\d+)$/);if(e)return new i(e[1],e[2]);if(e=t.match(/^[A-Z]{2}\\\\s*[0-9]+\\\\s*[0-9]+$/i),!e)throw new Error(\\\"Invalid grid reference\\\");var n=t.toUpperCase().charCodeAt(0)-\\\"A\\\".charCodeAt(0),r=t.toUpperCase().charCodeAt(1)-\\\"A\\\".charCodeAt(0);n>7&&n--,r>7&&r--;var o=(n-2)%5*5+r%5,s=19-5*Math.floor(n/5)-Math.floor(r/5),a=t.slice(2).trim().split(/\\\\s+/);if(1==a.length&&(a=[a[0].slice(0,a[0].length/2),a[0].slice(a[0].length/2)]),o<0||o>6||s<0||s>12)throw new Error(\\\"Invalid grid reference\\\");if(2!=a.length)throw new Error(\\\"Invalid grid reference\\\");if(a[0].length!=a[1].length)throw new Error(\\\"Invalid grid reference\\\");a[0]=(a[0]+\\\"00000\\\").slice(0,5),a[1]=(a[1]+\\\"00000\\\").slice(0,5);var u=o+a[0],l=s+a[1];return new i(u,l)},i.prototype.toString=function(t){if(t=void 0===t?10:Number(t),isNaN(t)||t%2!=0||t>16)throw new RangeError(\\\"Invalid precision ‘\\\"+t+\\\"’\\\");var e=this.easting,n=this.northing;if(isNaN(e)||isNaN(n))throw new Error(\\\"Invalid grid reference\\\");if(0==t){var r=Math.floor(e),i=e-r,o=Math.floor(n),s=n-o,a=(\\\"000000\\\"+r).slice(-6)+(i>0?i.toFixed(3).slice(1):\\\"\\\"),u=(o<1e6?(\\\"000000\\\"+o).slice(-6):o)+(s>0?s.toFixed(3).slice(1):\\\"\\\");return a+\\\",\\\"+u}var l=Math.floor(e/1e5),c=Math.floor(n/1e5);if(l<0||l>6||c<0||c>12)return\\\"\\\";var h=19-c-(19-c)%5+Math.floor((l+10)/5),f=5*(19-c)%25+l%5;h>7&&h++,f>7&&f++;var g=String.fromCharCode(h+\\\"A\\\".charCodeAt(0),f+\\\"A\\\".charCodeAt(0));return e=Math.floor(e%1e5/Math.pow(10,5-t/2)),n=Math.floor(n%1e5/Math.pow(10,5-t/2)),e=(\\\"00000000\\\"+e).slice(-t/2),n=(\\\"00000000\\\"+n).slice(-t/2),g+\\\" \\\"+e+\\\" \\\"+n},t.exports&&(t.exports=i)},\\\"0d58\\\":function(t,e,n){var r=n(\\\"ce10\\\"),i=n(\\\"e11e\\\");t.exports=Object.keys||function(t){return r(t,i)}},\\\"0dd1\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"c01c\\\"),i=n(\\\"d1bd\\\");function o(t,e){var n=t.length;if(1===n){var o=r(t[0],e);return o[0]?o:[o[1]]}var s=new Array(2*n),a=[.1,.1],u=[.1,.1],l=0;r(t[0],e,a),a[0]&&(s[l++]=a[0]);for(var c=1;c=a){var u=(n+o)/2;return[e,u-(i-e)/2,i,u+(i-e)/2]}var l=(e+i)/2;return[l-(o-n)/2,n,l+(o-n)/2,o]}},\\\"10ee\\\":function(t,e,n){\\\"use strict\\\";if(t.exports)var r=n(\\\"9d79\\\");if(t.exports)var i=n(\\\"6359\\\");function o(t,e,n,r,s,a,u){if(!(this instanceof o))return new o(t,e,n,r,s,a,u);if(void 0===u&&(u=i.datum.WGS84),!(1<=t&&t<=60))throw new Error(\\\"Invalid MGRS grid reference (zone ‘\\\"+t+\\\"’)\\\");if(1!=e.length)throw new Error(\\\"Invalid MGRS grid reference (band ‘\\\"+e+\\\"’)\\\");if(-1==o.latBands.indexOf(e))throw new Error(\\\"Invalid MGRS grid reference (band ‘\\\"+e+\\\"’)\\\");if(1!=n.length)throw new Error(\\\"Invalid MGRS grid reference (e100k ‘\\\"+n+\\\"’)\\\");if(1!=r.length)throw new Error(\\\"Invalid MGRS grid reference (n100k ‘\\\"+r+\\\"’)\\\");this.zone=Number(t),this.band=e,this.e100k=n,this.n100k=r,this.easting=Number(s),this.northing=Number(a),this.datum=u}o.latBands=\\\"CDEFGHJKLMNPQRSTUVWXX\\\",o.e100kLetters=[\\\"ABCDEFGH\\\",\\\"JKLMNPQR\\\",\\\"STUVWXYZ\\\"],o.n100kLetters=[\\\"ABCDEFGHJKLMNPQRSTUV\\\",\\\"FGHJKLMNPQRSTUVABCDE\\\"],r.prototype.toMgrs=function(){if(isNaN(this.zone+this.easting+this.northing))throw new Error(\\\"Invalid UTM coordinate ‘\\\"+this.toString()+\\\"’\\\");var t=this.zone,e=this.toLatLonE(),n=o.latBands.charAt(Math.floor(e.lat/8+10)),r=Math.floor(this.easting/1e5),i=o.e100kLetters[(t-1)%3].charAt(r-1),s=Math.floor(this.northing/1e5)%20,a=o.n100kLetters[(t-1)%2].charAt(s),u=this.easting%1e5,l=this.northing%1e5;return u=Number(u.toFixed(6)),l=Number(l.toFixed(6)),new o(t,n,i,a,u,l)},o.prototype.toUtm=function(){var t=this.zone,e=this.band,n=this.e100k,s=this.n100k,a=this.easting,u=this.northing,l=e>=\\\"N\\\"?\\\"N\\\":\\\"S\\\",c=o.e100kLetters[(t-1)%3].indexOf(n)+1,h=1e5*c,f=o.n100kLetters[(t-1)%2].indexOf(s),g=1e5*f,d=8*(o.latBands.indexOf(e)-10),p=1e5*Math.floor(new i(d,0).toUtm().northing/1e5),v=0;while(v+g+u=5?l:(l+\\\"00000\\\").slice(0,5),c=c.length>=5?c:(c+\\\"00000\\\").slice(0,5),new o(r,i,a,u,l,c)},o.prototype.toString=function(t){if(t=void 0===t?10:Number(t),-1==[2,4,6,8,10].indexOf(t))throw new Error(\\\"Invalid precision ‘\\\"+t+\\\"’\\\");var e=(\\\"00\\\"+this.zone).slice(-2),n=this.band,r=this.e100k,i=this.n100k,o=Math.floor(this.easting/Math.pow(10,5-t/2)),s=Math.floor(this.northing/Math.pow(10,5-t/2)),a=(\\\"00000\\\"+o).slice(-t/2),u=(\\\"00000\\\"+s).slice(-t/2);return e+n+\\\" \\\"+r+i+\\\" \\\"+a+\\\" \\\"+u},t.exports&&(t.exports=o)},\\\"12ef\\\":function(t,e,n){var r=n(\\\"29b8\\\");t.exports=function(t,e,n){switch(n=n||{},e=e||1,t){case\\\"point\\\":case\\\"points\\\":case void 0:return r.point(e,n.bbox);case\\\"polygon\\\":case\\\"polygons\\\":return r.polygon(e,n.num_vertices,n.max_radial_length,n.bbox);default:throw new Error(\\\"Unknown type given: valid options are points and polygons\\\")}}},1419:function(t,e,n){var r,i;\\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* @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(function(n,o){r=[],i=function(){return{isoContours:o()}}.apply(e,r),void 0===i||(t.exports=i)})(0,function(){var t={successCallback:null,verbose:!1},e={};function n(n,r,o){o=o||{};for(var s=Object.keys(t),a=0;a=e?8:0,u|=c>=e?4:0,u|=h>=e?2:0,u|=f>=e?1:0;var g,d,p,v,y=!1;if(5===u||10===u){var m=(l+c+h+f)/4;5===u&&m=0;d--)if(Math.abs(e[d][0][0]-f)<=r&&Math.abs(e[d][0][1]-g)<=r){for(var p=l.path.length-2;p>=0;--p)e[d].unshift(l.path[p]);h=!0;break}h||(e[n++]=l.path)}})}),e}function c(t,e,n){var r,i,o=t.length,s=[],l=[0,0,1,1,0,0,0,0,-1,0,1,1,-1,0,-1,0],c=[0,-1,0,0,1,1,1,1,0,-1,0,0,0,-1,0,0],h=[\\\"none\\\",\\\"left\\\",\\\"bottom\\\",\\\"left\\\",\\\"right\\\",\\\"none\\\",\\\"bottom\\\",\\\"left\\\",\\\"top\\\",\\\"top\\\",\\\"none\\\",\\\"top\\\",\\\"right\\\",\\\"right\\\",\\\"bottom\\\",\\\"none\\\"],f=[\\\"none\\\",\\\"bottom\\\",\\\"right\\\",\\\"right\\\",\\\"top\\\",\\\"top\\\",\\\"top\\\",\\\"top\\\",\\\"left\\\",\\\"bottom\\\",\\\"right\\\",\\\"right\\\",\\\"left\\\",\\\"bottom\\\",\\\"left\\\",\\\"none\\\"],g=(t[e][n],t[e][n]),d=g.cval,p=h[d],v=u(g,p);s.push([n+v[0],e+v[1]]),p=f[d],v=u(g,p),s.push([n+v[0],e+v[1]]),a(g);var y=n+l[d],m=e+c[d],x=d;while(y>=0&&m>=0&&m=0&&i.coordinates[0]-t.coordinates[0]<0)return 1;if(r.coordinates[0]-t.coordinates[0]<0&&i.coordinates[0]-t.coordinates[0]>=0)return-1;if(r.coordinates[0]-t.coordinates[0]===0&&i.coordinates[0]-t.coordinates[0]===0)return r.coordinates[1]-t.coordinates[1]>=0||i.coordinates[1]-t.coordinates[1]>=0?r.coordinates[1]-i.coordinates[1]:i.coordinates[1]-r.coordinates[1];var o=s(t.coordinates,r.coordinates,i.coordinates);if(o<0)return 1;if(o>0)return-1;var a=Math.pow(r.coordinates[0]-t.coordinates[0],2)+Math.pow(r.coordinates[1]-t.coordinates[1],2),u=Math.pow(i.coordinates[0]-t.coordinates[0],2)+Math.pow(i.coordinates[1]-t.coordinates[1],2);return a-u}),this.outerEdgesSorted=!0)}},{key:\\\"getOuterEdges\\\",value:function(){return this.sortOuterEdges(),this.outerEdges}},{key:\\\"getOuterEdge\\\",value:function(t){return this.sortOuterEdges(),this.outerEdges[t]}},{key:\\\"addInnerEdge\\\",value:function(t){this.innerEdges.push(t)}}]),t}();t.exports=a},1468:function(t,e){var n=1e3,r=60*n,i=60*r,o=24*i,s=365.25*o;function a(t){if(t=String(t),!(t.length>100)){var e=/^((?:\\\\d+)?\\\\.?\\\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(t);if(e){var a=parseFloat(e[1]),u=(e[2]||\\\"ms\\\").toLowerCase();switch(u){case\\\"years\\\":case\\\"year\\\":case\\\"yrs\\\":case\\\"yr\\\":case\\\"y\\\":return a*s;case\\\"days\\\":case\\\"day\\\":case\\\"d\\\":return a*o;case\\\"hours\\\":case\\\"hour\\\":case\\\"hrs\\\":case\\\"hr\\\":case\\\"h\\\":return a*i;case\\\"minutes\\\":case\\\"minute\\\":case\\\"mins\\\":case\\\"min\\\":case\\\"m\\\":return a*r;case\\\"seconds\\\":case\\\"second\\\":case\\\"secs\\\":case\\\"sec\\\":case\\\"s\\\":return a*n;case\\\"milliseconds\\\":case\\\"millisecond\\\":case\\\"msecs\\\":case\\\"msec\\\":case\\\"ms\\\":return a;default:return}}}}function u(t){return t>=o?Math.round(t/o)+\\\"d\\\":t>=i?Math.round(t/i)+\\\"h\\\":t>=r?Math.round(t/r)+\\\"m\\\":t>=n?Math.round(t/n)+\\\"s\\\":t+\\\"ms\\\"}function l(t){return c(t,o,\\\"day\\\")||c(t,i,\\\"hour\\\")||c(t,r,\\\"minute\\\")||c(t,n,\\\"second\\\")||t+\\\" ms\\\"}function c(t,e,n){if(!(t0)return a(t);if(\\\"number\\\"===n&&!1===isNaN(t))return e.long?l(t):u(t);throw new Error(\\\"val is not a non-empty string or a valid number. val=\\\"+JSON.stringify(t))}},1495:function(t,e,n){var r=n(\\\"86cc\\\"),i=n(\\\"cb7c\\\"),o=n(\\\"0d58\\\");t.exports=n(\\\"9e1e\\\")?Object.defineProperties:function(t,e){i(t);var n,s=o(e),a=s.length,u=0;while(a>u)r.f(t,n=s[u++],e[n]);return t}},\\\"14dd\\\":function(t,e,n){var r=n(\\\"716c\\\").coordEach;t.exports=function(t,e){if(!t)throw new Error(\\\"geojson is required\\\");return!1!==e&&void 0!==e||(t=JSON.parse(JSON.stringify(t))),r(t,function(t){var e=t[0],n=t[1];t[0]=n,t[1]=e}),t}},\\\"15b3\\\":function(t,e,n){var r=n(\\\"9fc0\\\"),i=n(\\\"8e19\\\"),o=n(\\\"0364\\\"),s=n(\\\"5174\\\"),a=n(\\\"baff\\\"),u=n(\\\"409f\\\"),l=n(\\\"31ff\\\"),c=l.toWgs84,h=a.feature,f=o.geomEach,g=l.toMercator,d=o.featureEach,p=a.featureCollection,v=a.radiansToDistance,y=a.distanceToRadians;function m(t,e,n,r){var o,s=t.properties||{},a=\\\"Feature\\\"===t.type?t.geometry:t;if(\\\"GeometryCollection\\\"===a.type){var l=[];return f(t,function(t){var i=m(t,e,n,r);i&&l.push(i)}),p(l)}var d=u(t),I=d[1]>50&&d[3]>50;if(I){var N=b(a);o={type:a.type,coordinates:E(a.coordinates,N)}}else o=g(a);var C,S=new i.io.GeoJSONReader,M=S.read(o),_=v(y(e,n),\\\"meters\\\"),L=M.buffer(_),P=new i.io.GeoJSONWriter;if(L=P.write(L),!x(L.coordinates))return C=I?{type:L.type,coordinates:w(L.coordinates,N)}:c(L),C.geometry?C:h(C,s)}function x(t){return Array.isArray(t[0])?x(t[0]):isNaN(t[0])}function E(t,e){return\\\"object\\\"!==typeof t[0]?e(t):t.map(function(t){return E(t,e)})}function w(t,e){return\\\"object\\\"!==typeof t[0]?e.invert(t):t.map(function(t){return w(t,e)})}function b(t){var e=s(t).geometry.coordinates.reverse(),n=e.map(function(t){return-t}),i=r.geoTransverseMercator().center(e).rotate(n).scale(6373e3);return i}t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"geojson is required\\\");if(void 0===e)throw new Error(\\\"radius is required\\\");if(r<=0)throw new Error(\\\"steps must be greater than 0\\\");r=r||64,n=n||\\\"kilometers\\\";var i=[];switch(t.type){case\\\"GeometryCollection\\\":return f(t,function(t){var o=m(t,e,n,r);o&&i.push(o)}),p(i);case\\\"FeatureCollection\\\":return d(t,function(t){var o=m(t,e,n,r);o&&d(o,function(t){t&&i.push(t)})}),p(i)}return m(t,e,n,r)}},\\\"1a0a\\\":function(t,e,n){var r=n(\\\"00a2\\\"),i=r.getCoord,o=r.getGeom;t.exports=function(t,e){var n=i(t),r=o(e),s=r.coordinates,a=s[0];if(a.length<4)throw new Error(\\\"OuterRing of a Polygon must have 4 or more Positions.\\\");var u=e.properties||{},l=u.a,c=u.b,h=u.c,f=n[0],g=n[1],d=a[0][0],p=a[0][1],v=void 0!==l?l:a[0][2],y=a[1][0],m=a[1][1],x=void 0!==c?c:a[1][2],E=a[2][0],w=a[2][1],b=void 0!==h?h:a[2][2],I=(b*(f-d)*(g-m)+v*(f-y)*(g-w)+x*(f-E)*(g-p)-x*(f-d)*(g-w)-b*(f-y)*(g-p)-v*(f-E)*(g-m))/((f-d)*(g-m)+(f-y)*(g-w)+(f-E)*(g-p)-(f-d)*(g-w)-(f-y)*(g-p)-(f-E)*(g-m));return I}},\\\"1a3f\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"1f25\\\"),i=n(\\\"8ff7\\\"),o=n(\\\"ca39\\\");function s(t){var e=t.length;if(0===e)return[];if(1===e)return[[0]];var n=t[0].length;return 0===n?[]:1===n?r(t):2===n?i(t):o(t,n)}t.exports=s},\\\"1bf7\\\":function(t,e,n){var r=n(\\\"feb7\\\"),i=r.polygon,o=r.featureCollection;function s(t,e,n){this.a=t,this.b=e,this.c=n;var r,i,o=e.x-t.x,s=e.y-t.y,a=n.x-t.x,u=n.y-t.y,l=o*(t.x+e.x)+s*(t.y+e.y),c=a*(t.x+n.x)+u*(t.y+n.y),h=2*(o*(n.y-e.y)-s*(n.x-e.x));this.x=(u*l-s*c)/h,this.y=(o*c-a*l)/h,r=this.x-t.x,i=this.y-t.y,this.r=r*r+i*i}function a(t,e){return e.x-t.x}function u(t){var e,n,r,i,o,s=t.length;t:while(s){n=t[--s],e=t[--s],r=s;while(r)if(o=t[--r],i=t[--r],e===i&&n===o||e===o&&n===i){t.splice(s,2),t.splice(r,2),s-=2;continue t}}}function l(t){if(t.length<3)return[];t.sort(a);var e,n,r,i,o,l,c=t.length-1,h=t[c].x,f=t[0].x,g=t[c].y,d=g,p=1e-12;while(c--)t[c].yd&&(d=t[c].y);var v,y=f-h,m=d-g,x=y>m?y:m,E=.5*(f+h),w=.5*(d+g),b=[new s({x:E-20*x,y:w-x,__sentinel:!0},{x:E,y:w+20*x,__sentinel:!0},{x:E+20*x,y:w-x,__sentinel:!0})],I=[],N=[];c=t.length;while(c--){N.length=0,v=b.length;while(v--)y=t[c].x-b[v].x,y>0&&y*y>b[v].r?(I.push(b[v]),b.splice(v,1)):(m=t[c].y-b[v].y,y*y+m*m>b[v].r||(N.push(b[v].a,b[v].b,b[v].b,b[v].c,b[v].c,b[v].a),b.splice(v,1)));u(N),v=N.length;while(v)n=N[--v],e=N[--v],r=t[c],i=n.x-e.x,o=n.y-e.y,l=2*(i*(r.y-n.y)-o*(r.x-n.x)),Math.abs(l)>p&&b.push(new s(e,n,r))}Array.prototype.push.apply(I,b),c=I.length;while(c--)(I[c].a.__sentinel||I[c].b.__sentinel||I[c].c.__sentinel)&&I.splice(c,1);return I}t.exports=function(t,e){if(\\\"FeatureCollection\\\"!==t.type)throw new Error(\\\"points must be a FeatureCollection\\\");var n=!1;return o(l(t.features.map(function(t){var r={x:t.geometry.coordinates[0],y:t.geometry.coordinates[1]};return e?r.z=t.properties[e]:3===t.geometry.coordinates.length&&(n=!0,r.z=t.geometry.coordinates[2]),r})).map(function(t){var e=[t.a.x,t.a.y],r=[t.b.x,t.b.y],o=[t.c.x,t.c.y],s={};return n?(e.push(t.a.z),r.push(t.b.z),o.push(t.c.z)):s={a:t.a.z,b:t.b.z,c:t.c.z},i([[e,r,o,e]],s)}))}},\\\"1bfd\\\":function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"f13f\\\"),o=n(\\\"48f0\\\"),s=n(\\\"feb7\\\"),a=n(\\\"8dde\\\"),u=n(\\\"409f\\\"),l=n(\\\"00a2\\\"),c=n(\\\"d592\\\"),h=n(\\\"42a9\\\"),f=n(\\\"2bfa\\\"),g=s.point,d=r.coordEach,p=r.featureEach,v=l.getCoord,y=l.getCoords,m=l.getGeomType;function x(t,e,n){var r=\\\"Point\\\"===m(t);return n=E(t,n),1===e||r?t:(d(t,function(t){var r=h(n,t),i=c(n,t),o=r*e,s=y(f(n,o,i));t[0]=s[0],t[1]=s[1],3===t.length&&(t[2]*=e)}),t)}function E(t,e){if(void 0!==e&&null!==e||(e=\\\"centroid\\\"),Array.isArray(e)||\\\"object\\\"===typeof e)return v(e);var n=t.bbox?t.bbox:u(t),r=n[0],i=n[1],s=n[2],l=n[3];switch(e){case\\\"sw\\\":case\\\"southwest\\\":case\\\"westsouth\\\":case\\\"bottomleft\\\":return g([r,i]);case\\\"se\\\":case\\\"southeast\\\":case\\\"eastsouth\\\":case\\\"bottomright\\\":return g([s,i]);case\\\"nw\\\":case\\\"northwest\\\":case\\\"westnorth\\\":case\\\"topleft\\\":return g([r,l]);case\\\"ne\\\":case\\\"northeast\\\":case\\\"eastnorth\\\":case\\\"topright\\\":return g([s,l]);case\\\"center\\\":return o(t);case void 0:case null:case\\\"centroid\\\":return a(t);default:throw new Error(\\\"invalid origin\\\")}}t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"geojson required\\\");if(\\\"number\\\"!==typeof e||0===e)throw new Error(\\\"invalid factor\\\");var o=Array.isArray(n)||\\\"object\\\"===typeof n;return!0!==r&&(t=i(t)),\\\"FeatureCollection\\\"!==t.type||o?x(t,e,n):(p(t,function(r,i){t.features[i]=x(r,e,n)}),t)}},\\\"1d2b\\\":function(t,e,n){\\\"use strict\\\";t.exports=function(t,e){return function(){for(var n=new Array(arguments.length),r=0;rt[n][0]&&(n=r);return en?[[n],[e]]:[[e]]}t.exports=r},\\\"1fac\\\":function(t,e){function n(t,e,r){var i,o,s,a,u,l,c,h,f,g,d=0,p=0,v=\\\"FeatureCollection\\\"===t.type,y=\\\"Feature\\\"===t.type,m=v?t.features.length:1;for(i=0;i=200&&t<300},headers:{common:{Accept:\\\"application/json, text/plain, */*\\\"}}};r.forEach([\\\"delete\\\",\\\"get\\\",\\\"head\\\"],function(t){u.headers[t]={}}),r.forEach([\\\"post\\\",\\\"put\\\",\\\"patch\\\"],function(t){u.headers[t]=r.merge(o)}),t.exports=u}).call(this,n(\\\"f28c\\\"))},\\\"24ad\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"a48a\\\"),i=n(\\\"dca5\\\");function o(t){for(var e=0,n=Math.max,r=0,i=t.length;r>1,s=u(t[o],e);s<=0?(0===s&&(i=o),n=o+1):s>0&&(r=o-1)}return i}function g(t,e){for(var n=new Array(t.length),i=0,o=n.length;i=t.length||0!==u(t[v],s))break}return n}function d(t,e){if(!e)return g(h(v(t,0)),t,0);for(var n=new Array(e),r=0;r>>l&1&&u.push(i[l]);e.push(u)}return c(e)}function v(t,e){if(e<0)return[];for(var n=[],i=(1<0?t+n[e-1]:t}function d(t,e){t=2*t*Math.PI/l[l.length-1];var n=Math.random();u.push([n*o*Math.sin(t),n*o*Math.cos(t)])}return f(a)}},\\\"2aba\\\":function(t,e,n){var r=n(\\\"7726\\\"),i=n(\\\"32e9\\\"),o=n(\\\"69a8\\\"),s=n(\\\"ca5a\\\")(\\\"src\\\"),a=n(\\\"fa5b\\\"),u=\\\"toString\\\",l=(\\\"\\\"+a).split(u);n(\\\"8378\\\").inspectSource=function(t){return a.call(t)},(t.exports=function(t,e,n,a){var u=\\\"function\\\"==typeof n;u&&(o(n,\\\"name\\\")||i(n,\\\"name\\\",e)),t[e]!==n&&(u&&(o(n,s)||i(n,s,t[e]?\\\"\\\"+t[e]:l.join(String(e)))),t===r?t[e]=n:a?t[e]?t[e]=n:i(t,e,n):(delete t[e],i(t,e,n)))})(Function.prototype,u,function(){return\\\"function\\\"==typeof this&&this[s]||a.call(this)})},\\\"2aeb\\\":function(t,e,n){var r=n(\\\"cb7c\\\"),i=n(\\\"1495\\\"),o=n(\\\"e11e\\\"),s=n(\\\"613b\\\")(\\\"IE_PROTO\\\"),a=function(){},u=\\\"prototype\\\",l=function(){var t,e=n(\\\"230e\\\")(\\\"iframe\\\"),r=o.length,i=\\\"<\\\",s=\\\">\\\";e.style.display=\\\"none\\\",n(\\\"fab2\\\").appendChild(e),e.src=\\\"javascript:\\\",t=e.contentWindow.document,t.open(),t.write(i+\\\"script\\\"+s+\\\"document.F=Object\\\"+i+\\\"/script\\\"+s),t.close(),l=t.F;while(r--)delete l[u][o[r]];return l()};t.exports=Object.create||function(t,e){var n;return null!==t?(a[u]=r(t),n=new a,a[u]=null,n[s]=t):n=l(),void 0===e?n:i(n,e)}},\\\"2b4c\\\":function(t,e,n){var r=n(\\\"5537\\\")(\\\"wks\\\"),i=n(\\\"ca5a\\\"),o=n(\\\"7726\\\").Symbol,s=\\\"function\\\"==typeof o,a=t.exports=function(t){return r[t]||(r[t]=s&&o[t]||(s?o:i)(\\\"Symbol.\\\"+t))};a.store=r},\\\"2bfa\\\":function(t,e,n){var r=n(\\\"feb7\\\"),i=n(\\\"00a2\\\").getCoord,o=n(\\\"570b\\\").LatLonSpherical,s=r.point,a=r.radiansToDistance,u=r.distanceToRadians;t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"origin is required\\\");if(void 0===e||null===e)throw new Error(\\\"distance is required\\\");if(void 0===n||null===n)throw new Error(\\\"bearing is required\\\");if(!(e>=0))throw new Error(\\\"distance must be greater than 0\\\");r=r||\\\"kilometers\\\";var l=a(u(e,r),\\\"meters\\\"),c=i(t),h=new o(c[1],c[0]),f=h.rhumbDestinationPoint(l,n);return f.lon+=f.lon-c[0]>180?-360:c[0]-f.lon>180?360:0,s([f.lon,f.lat])}},\\\"2c69\\\":function(t,e,n){\\\"use strict\\\";function r(t,e,n){var r,i,a,u,l,c=t.length,h=s(t[0],e),f=[];for(n||(n=[]),r=1;re[2]&&(n|=2),t[1]e[3]&&(n|=8),n}t.exports=r,r.polyline=r,r.polygon=i},\\\"2d00\\\":function(t,e){t.exports=!1},\\\"2d83\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"387f\\\");t.exports=function(t,e,n,i,o){var s=new Error(t);return r(s,e,n,i,o)}},\\\"2d95\\\":function(t,e){var n={}.toString;t.exports=function(t){return n.call(t).slice(8,-1)}},\\\"2e67\\\":function(t,e,n){\\\"use strict\\\";t.exports=function(t){return!(!t||!t.__CANCEL__)}},\\\"2e74\\\":function(t,e,n){\\\"use strict\\\";if(t.exports)var r=n(\\\"6359\\\");r.prototype.distanceTo=function(t){if(!(t instanceof r))throw new TypeError(\\\"point is not LatLon object\\\");try{return Number(this.inverse(t).distance.toFixed(3))}catch(e){return NaN}},r.prototype.initialBearingTo=function(t){if(!(t instanceof r))throw new TypeError(\\\"point is not LatLon object\\\");try{return Number(this.inverse(t).initialBearing.toFixed(9))}catch(e){return NaN}},r.prototype.finalBearingTo=function(t){if(!(t instanceof r))throw new TypeError(\\\"point is not LatLon object\\\");try{return Number(this.inverse(t).finalBearing.toFixed(9))}catch(e){return NaN}},r.prototype.destinationPoint=function(t,e){return this.direct(Number(t),Number(e)).point},r.prototype.finalBearingOn=function(t,e){return Number(this.direct(Number(t),Number(e)).finalBearing.toFixed(9))},r.prototype.direct=function(t,e){var n,i,o,s,a,u=this.lat.toRadians(),l=this.lon.toRadians(),c=e.toRadians(),h=t,f=this.datum.ellipsoid.a,g=this.datum.ellipsoid.b,d=this.datum.ellipsoid.f,p=Math.sin(c),v=Math.cos(c),y=(1-d)*Math.tan(u),m=1/Math.sqrt(1+y*y),x=y*m,E=Math.atan2(y,v),w=m*p,b=1-w*w,I=b*(f*f-g*g)/(g*g),N=1+I/16384*(4096+I*(I*(320-175*I)-768)),C=I/1024*(256+I*(I*(74-47*I)-128)),S=h/(g*N),M=0;do{n=Math.cos(2*E+S),i=Math.sin(S),o=Math.cos(S),s=C*i*(n+C/4*(o*(2*n*n-1)-C/6*n*(4*i*i-3)*(4*n*n-3))),a=S,S=h/(g*N)+s}while(Math.abs(S-a)>1e-12&&++M<100);if(M>=100)throw new Error(\\\"Formula failed to converge\\\");var _=x*i-m*o*v,L=Math.atan2(x*o+m*i*v,(1-d)*Math.sqrt(w*w+_*_)),P=Math.atan2(i*p,m*o-x*i*v),R=d/16*b*(4+d*(4-3*b)),T=P-(1-R)*d*w*(S+R*i*(n+R*o*(2*n*n-1))),O=(l+T+3*Math.PI)%(2*Math.PI)-Math.PI,A=Math.atan2(w,-_);return A=(A+2*Math.PI)%(2*Math.PI),{point:new r(L.toDegrees(),O.toDegrees(),this.datum),finalBearing:A.toDegrees(),iterations:M}},r.prototype.inverse=function(t){var e=this,n=t;-180==e.lon&&(e.lon=180);var r,i,o,s,a,u,l=e.lat.toRadians(),c=e.lon.toRadians(),h=n.lat.toRadians(),f=n.lon.toRadians(),g=this.datum.ellipsoid.a,d=this.datum.ellipsoid.b,p=this.datum.ellipsoid.f,v=f-c,y=(1-p)*Math.tan(l),m=1/Math.sqrt(1+y*y),x=y*m,E=(1-p)*Math.tan(h),w=1/Math.sqrt(1+E*E),b=E*w,I=0,N=0,C=0,S=0,M=0,_=v,L=0;do{if(r=Math.sin(_),i=Math.cos(_),o=w*r*(w*r)+(m*b-x*w*i)*(m*b-x*w*i),0==o)break;if(I=Math.sqrt(o),N=x*b+m*w*i,C=Math.atan2(I,N),s=m*w*r/I,S=1-s*s,M=0!=S?N-2*x*b/S:0,a=p/16*S*(4+p*(4-3*S)),u=_,_=v+(1-a)*p*s*(C+a*I*(M+a*N*(2*M*M-1))),Math.abs(_)>Math.PI)throw new Error(\\\"λ > π\\\")}while(Math.abs(_-u)>1e-12&&++L<1e3);if(L>=1e3)throw new Error(\\\"Formula failed to converge\\\");var P=S*(g*g-d*d)/(d*d),R=1+P/16384*(4096+P*(P*(320-175*P)-768)),T=P/1024*(256+P*(P*(74-47*P)-128)),O=T*I*(M+T/4*(N*(2*M*M-1)-T/6*M*(4*I*I-3)*(4*M*M-3))),A=d*R*(C-O),D=Math.atan2(w*r,m*b-x*w*i),F=Math.atan2(m*r,-x*w+m*b*i);return D=(D+2*Math.PI)%(2*Math.PI),F=(F+2*Math.PI)%(2*Math.PI),{distance:A,initialBearing:0==A?NaN:D.toDegrees(),finalBearing:0==A?NaN:F.toDegrees(),iterations:L}},void 0===Number.prototype.toRadians&&(Number.prototype.toRadians=function(){return this*Math.PI/180}),void 0===Number.prototype.toDegrees&&(Number.prototype.toDegrees=function(){return 180*this/Math.PI}),t.exports&&(t.exports=r)},\\\"2ef0\\\":function(t,e,n){(function(t,r){var i;\\n/**\\n * @license\\n * Lodash \\n * Copyright OpenJS Foundation and other contributors \\n * Released under MIT license \\n * Based on Underscore.js 1.8.3 \\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\\n */(function(){var o,s=\\\"4.17.15\\\",a=200,u=\\\"Unsupported core-js use. Try https://npms.io/search?q=ponyfill.\\\",l=\\\"Expected a function\\\",c=\\\"__lodash_hash_undefined__\\\",h=500,f=\\\"__lodash_placeholder__\\\",g=1,d=2,p=4,v=1,y=2,m=1,x=2,E=4,w=8,b=16,I=32,N=64,C=128,S=256,M=512,_=30,L=\\\"...\\\",P=800,R=16,T=1,O=2,A=3,D=1/0,F=9007199254740991,k=17976931348623157e292,G=NaN,V=4294967295,q=V-1,B=V>>>1,z=[[\\\"ary\\\",C],[\\\"bind\\\",m],[\\\"bindKey\\\",x],[\\\"curry\\\",w],[\\\"curryRight\\\",b],[\\\"flip\\\",M],[\\\"partial\\\",I],[\\\"partialRight\\\",N],[\\\"rearg\\\",S]],j=\\\"[object Arguments]\\\",U=\\\"[object Array]\\\",X=\\\"[object AsyncFunction]\\\",Y=\\\"[object Boolean]\\\",W=\\\"[object Date]\\\",H=\\\"[object DOMException]\\\",J=\\\"[object Error]\\\",Z=\\\"[object Function]\\\",K=\\\"[object GeneratorFunction]\\\",$=\\\"[object Map]\\\",Q=\\\"[object Number]\\\",tt=\\\"[object Null]\\\",et=\\\"[object Object]\\\",nt=\\\"[object Promise]\\\",rt=\\\"[object Proxy]\\\",it=\\\"[object RegExp]\\\",ot=\\\"[object Set]\\\",st=\\\"[object String]\\\",at=\\\"[object Symbol]\\\",ut=\\\"[object Undefined]\\\",lt=\\\"[object WeakMap]\\\",ct=\\\"[object WeakSet]\\\",ht=\\\"[object ArrayBuffer]\\\",ft=\\\"[object DataView]\\\",gt=\\\"[object Float32Array]\\\",dt=\\\"[object Float64Array]\\\",pt=\\\"[object Int8Array]\\\",vt=\\\"[object Int16Array]\\\",yt=\\\"[object Int32Array]\\\",mt=\\\"[object Uint8Array]\\\",xt=\\\"[object Uint8ClampedArray]\\\",Et=\\\"[object Uint16Array]\\\",wt=\\\"[object Uint32Array]\\\",bt=/\\\\b__p \\\\+= '';/g,It=/\\\\b(__p \\\\+=) '' \\\\+/g,Nt=/(__e\\\\(.*?\\\\)|\\\\b__t\\\\)) \\\\+\\\\n'';/g,Ct=/&(?:amp|lt|gt|quot|#39);/g,St=/[&<>\\\"']/g,Mt=RegExp(Ct.source),_t=RegExp(St.source),Lt=/<%-([\\\\s\\\\S]+?)%>/g,Pt=/<%([\\\\s\\\\S]+?)%>/g,Rt=/<%=([\\\\s\\\\S]+?)%>/g,Tt=/\\\\.|\\\\[(?:[^[\\\\]]*|([\\\"'])(?:(?!\\\\1)[^\\\\\\\\]|\\\\\\\\.)*?\\\\1)\\\\]/,Ot=/^\\\\w*$/,At=/[^.[\\\\]]+|\\\\[(?:(-?\\\\d+(?:\\\\.\\\\d+)?)|([\\\"'])((?:(?!\\\\2)[^\\\\\\\\]|\\\\\\\\.)*?)\\\\2)\\\\]|(?=(?:\\\\.|\\\\[\\\\])(?:\\\\.|\\\\[\\\\]|$))/g,Dt=/[\\\\\\\\^$.*+?()[\\\\]{}|]/g,Ft=RegExp(Dt.source),kt=/^\\\\s+|\\\\s+$/g,Gt=/^\\\\s+/,Vt=/\\\\s+$/,qt=/\\\\{(?:\\\\n\\\\/\\\\* \\\\[wrapped with .+\\\\] \\\\*\\\\/)?\\\\n?/,Bt=/\\\\{\\\\n\\\\/\\\\* \\\\[wrapped with (.+)\\\\] \\\\*/,zt=/,? & /,jt=/[^\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\x7f]+/g,Ut=/\\\\\\\\(\\\\\\\\)?/g,Xt=/\\\\$\\\\{([^\\\\\\\\}]*(?:\\\\\\\\.[^\\\\\\\\}]*)*)\\\\}/g,Yt=/\\\\w*$/,Wt=/^[-+]0x[0-9a-f]+$/i,Ht=/^0b[01]+$/i,Jt=/^\\\\[object .+?Constructor\\\\]$/,Zt=/^0o[0-7]+$/i,Kt=/^(?:0|[1-9]\\\\d*)$/,$t=/[\\\\xc0-\\\\xd6\\\\xd8-\\\\xf6\\\\xf8-\\\\xff\\\\u0100-\\\\u017f]/g,Qt=/($^)/,te=/['\\\\n\\\\r\\\\u2028\\\\u2029\\\\\\\\]/g,ee=\\\"\\\\\\\\ud800-\\\\\\\\udfff\\\",ne=\\\"\\\\\\\\u0300-\\\\\\\\u036f\\\",re=\\\"\\\\\\\\ufe20-\\\\\\\\ufe2f\\\",ie=\\\"\\\\\\\\u20d0-\\\\\\\\u20ff\\\",oe=ne+re+ie,se=\\\"\\\\\\\\u2700-\\\\\\\\u27bf\\\",ae=\\\"a-z\\\\\\\\xdf-\\\\\\\\xf6\\\\\\\\xf8-\\\\\\\\xff\\\",ue=\\\"\\\\\\\\xac\\\\\\\\xb1\\\\\\\\xd7\\\\\\\\xf7\\\",le=\\\"\\\\\\\\x00-\\\\\\\\x2f\\\\\\\\x3a-\\\\\\\\x40\\\\\\\\x5b-\\\\\\\\x60\\\\\\\\x7b-\\\\\\\\xbf\\\",ce=\\\"\\\\\\\\u2000-\\\\\\\\u206f\\\",he=\\\" \\\\\\\\t\\\\\\\\x0b\\\\\\\\f\\\\\\\\xa0\\\\\\\\ufeff\\\\\\\\n\\\\\\\\r\\\\\\\\u2028\\\\\\\\u2029\\\\\\\\u1680\\\\\\\\u180e\\\\\\\\u2000\\\\\\\\u2001\\\\\\\\u2002\\\\\\\\u2003\\\\\\\\u2004\\\\\\\\u2005\\\\\\\\u2006\\\\\\\\u2007\\\\\\\\u2008\\\\\\\\u2009\\\\\\\\u200a\\\\\\\\u202f\\\\\\\\u205f\\\\\\\\u3000\\\",fe=\\\"A-Z\\\\\\\\xc0-\\\\\\\\xd6\\\\\\\\xd8-\\\\\\\\xde\\\",ge=\\\"\\\\\\\\ufe0e\\\\\\\\ufe0f\\\",de=ue+le+ce+he,pe=\\\"['’]\\\",ve=\\\"[\\\"+ee+\\\"]\\\",ye=\\\"[\\\"+de+\\\"]\\\",me=\\\"[\\\"+oe+\\\"]\\\",xe=\\\"\\\\\\\\d+\\\",Ee=\\\"[\\\"+se+\\\"]\\\",we=\\\"[\\\"+ae+\\\"]\\\",be=\\\"[^\\\"+ee+de+xe+se+ae+fe+\\\"]\\\",Ie=\\\"\\\\\\\\ud83c[\\\\\\\\udffb-\\\\\\\\udfff]\\\",Ne=\\\"(?:\\\"+me+\\\"|\\\"+Ie+\\\")\\\",Ce=\\\"[^\\\"+ee+\\\"]\\\",Se=\\\"(?:\\\\\\\\ud83c[\\\\\\\\udde6-\\\\\\\\uddff]){2}\\\",Me=\\\"[\\\\\\\\ud800-\\\\\\\\udbff][\\\\\\\\udc00-\\\\\\\\udfff]\\\",_e=\\\"[\\\"+fe+\\\"]\\\",Le=\\\"\\\\\\\\u200d\\\",Pe=\\\"(?:\\\"+we+\\\"|\\\"+be+\\\")\\\",Re=\\\"(?:\\\"+_e+\\\"|\\\"+be+\\\")\\\",Te=\\\"(?:\\\"+pe+\\\"(?:d|ll|m|re|s|t|ve))?\\\",Oe=\\\"(?:\\\"+pe+\\\"(?:D|LL|M|RE|S|T|VE))?\\\",Ae=Ne+\\\"?\\\",De=\\\"[\\\"+ge+\\\"]?\\\",Fe=\\\"(?:\\\"+Le+\\\"(?:\\\"+[Ce,Se,Me].join(\\\"|\\\")+\\\")\\\"+De+Ae+\\\")*\\\",ke=\\\"\\\\\\\\d*(?:1st|2nd|3rd|(?![123])\\\\\\\\dth)(?=\\\\\\\\b|[A-Z_])\\\",Ge=\\\"\\\\\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\\\\\dTH)(?=\\\\\\\\b|[a-z_])\\\",Ve=De+Ae+Fe,qe=\\\"(?:\\\"+[Ee,Se,Me].join(\\\"|\\\")+\\\")\\\"+Ve,Be=\\\"(?:\\\"+[Ce+me+\\\"?\\\",me,Se,Me,ve].join(\\\"|\\\")+\\\")\\\",ze=RegExp(pe,\\\"g\\\"),je=RegExp(me,\\\"g\\\"),Ue=RegExp(Ie+\\\"(?=\\\"+Ie+\\\")|\\\"+Be+Ve,\\\"g\\\"),Xe=RegExp([_e+\\\"?\\\"+we+\\\"+\\\"+Te+\\\"(?=\\\"+[ye,_e,\\\"$\\\"].join(\\\"|\\\")+\\\")\\\",Re+\\\"+\\\"+Oe+\\\"(?=\\\"+[ye,_e+Pe,\\\"$\\\"].join(\\\"|\\\")+\\\")\\\",_e+\\\"?\\\"+Pe+\\\"+\\\"+Te,_e+\\\"+\\\"+Oe,Ge,ke,xe,qe].join(\\\"|\\\"),\\\"g\\\"),Ye=RegExp(\\\"[\\\"+Le+ee+oe+ge+\\\"]\\\"),We=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,He=[\\\"Array\\\",\\\"Buffer\\\",\\\"DataView\\\",\\\"Date\\\",\\\"Error\\\",\\\"Float32Array\\\",\\\"Float64Array\\\",\\\"Function\\\",\\\"Int8Array\\\",\\\"Int16Array\\\",\\\"Int32Array\\\",\\\"Map\\\",\\\"Math\\\",\\\"Object\\\",\\\"Promise\\\",\\\"RegExp\\\",\\\"Set\\\",\\\"String\\\",\\\"Symbol\\\",\\\"TypeError\\\",\\\"Uint8Array\\\",\\\"Uint8ClampedArray\\\",\\\"Uint16Array\\\",\\\"Uint32Array\\\",\\\"WeakMap\\\",\\\"_\\\",\\\"clearTimeout\\\",\\\"isFinite\\\",\\\"parseInt\\\",\\\"setTimeout\\\"],Je=-1,Ze={};Ze[gt]=Ze[dt]=Ze[pt]=Ze[vt]=Ze[yt]=Ze[mt]=Ze[xt]=Ze[Et]=Ze[wt]=!0,Ze[j]=Ze[U]=Ze[ht]=Ze[Y]=Ze[ft]=Ze[W]=Ze[J]=Ze[Z]=Ze[$]=Ze[Q]=Ze[et]=Ze[it]=Ze[ot]=Ze[st]=Ze[lt]=!1;var Ke={};Ke[j]=Ke[U]=Ke[ht]=Ke[ft]=Ke[Y]=Ke[W]=Ke[gt]=Ke[dt]=Ke[pt]=Ke[vt]=Ke[yt]=Ke[$]=Ke[Q]=Ke[et]=Ke[it]=Ke[ot]=Ke[st]=Ke[at]=Ke[mt]=Ke[xt]=Ke[Et]=Ke[wt]=!0,Ke[J]=Ke[Z]=Ke[lt]=!1;var $e={\\\"À\\\":\\\"A\\\",\\\"Á\\\":\\\"A\\\",\\\"Â\\\":\\\"A\\\",\\\"Ã\\\":\\\"A\\\",\\\"Ä\\\":\\\"A\\\",\\\"Å\\\":\\\"A\\\",\\\"à\\\":\\\"a\\\",\\\"á\\\":\\\"a\\\",\\\"â\\\":\\\"a\\\",\\\"ã\\\":\\\"a\\\",\\\"ä\\\":\\\"a\\\",\\\"å\\\":\\\"a\\\",\\\"Ç\\\":\\\"C\\\",\\\"ç\\\":\\\"c\\\",\\\"Ð\\\":\\\"D\\\",\\\"ð\\\":\\\"d\\\",\\\"È\\\":\\\"E\\\",\\\"É\\\":\\\"E\\\",\\\"Ê\\\":\\\"E\\\",\\\"Ë\\\":\\\"E\\\",\\\"è\\\":\\\"e\\\",\\\"é\\\":\\\"e\\\",\\\"ê\\\":\\\"e\\\",\\\"ë\\\":\\\"e\\\",\\\"Ì\\\":\\\"I\\\",\\\"Í\\\":\\\"I\\\",\\\"Î\\\":\\\"I\\\",\\\"Ï\\\":\\\"I\\\",\\\"ì\\\":\\\"i\\\",\\\"í\\\":\\\"i\\\",\\\"î\\\":\\\"i\\\",\\\"ï\\\":\\\"i\\\",\\\"Ñ\\\":\\\"N\\\",\\\"ñ\\\":\\\"n\\\",\\\"Ò\\\":\\\"O\\\",\\\"Ó\\\":\\\"O\\\",\\\"Ô\\\":\\\"O\\\",\\\"Õ\\\":\\\"O\\\",\\\"Ö\\\":\\\"O\\\",\\\"Ø\\\":\\\"O\\\",\\\"ò\\\":\\\"o\\\",\\\"ó\\\":\\\"o\\\",\\\"ô\\\":\\\"o\\\",\\\"õ\\\":\\\"o\\\",\\\"ö\\\":\\\"o\\\",\\\"ø\\\":\\\"o\\\",\\\"Ù\\\":\\\"U\\\",\\\"Ú\\\":\\\"U\\\",\\\"Û\\\":\\\"U\\\",\\\"Ü\\\":\\\"U\\\",\\\"ù\\\":\\\"u\\\",\\\"ú\\\":\\\"u\\\",\\\"û\\\":\\\"u\\\",\\\"ü\\\":\\\"u\\\",\\\"Ý\\\":\\\"Y\\\",\\\"ý\\\":\\\"y\\\",\\\"ÿ\\\":\\\"y\\\",\\\"Æ\\\":\\\"Ae\\\",\\\"æ\\\":\\\"ae\\\",\\\"Þ\\\":\\\"Th\\\",\\\"þ\\\":\\\"th\\\",\\\"ß\\\":\\\"ss\\\",\\\"Ā\\\":\\\"A\\\",\\\"Ă\\\":\\\"A\\\",\\\"Ą\\\":\\\"A\\\",\\\"ā\\\":\\\"a\\\",\\\"ă\\\":\\\"a\\\",\\\"ą\\\":\\\"a\\\",\\\"Ć\\\":\\\"C\\\",\\\"Ĉ\\\":\\\"C\\\",\\\"Ċ\\\":\\\"C\\\",\\\"Č\\\":\\\"C\\\",\\\"ć\\\":\\\"c\\\",\\\"ĉ\\\":\\\"c\\\",\\\"ċ\\\":\\\"c\\\",\\\"č\\\":\\\"c\\\",\\\"Ď\\\":\\\"D\\\",\\\"Đ\\\":\\\"D\\\",\\\"ď\\\":\\\"d\\\",\\\"đ\\\":\\\"d\\\",\\\"Ē\\\":\\\"E\\\",\\\"Ĕ\\\":\\\"E\\\",\\\"Ė\\\":\\\"E\\\",\\\"Ę\\\":\\\"E\\\",\\\"Ě\\\":\\\"E\\\",\\\"ē\\\":\\\"e\\\",\\\"ĕ\\\":\\\"e\\\",\\\"ė\\\":\\\"e\\\",\\\"ę\\\":\\\"e\\\",\\\"ě\\\":\\\"e\\\",\\\"Ĝ\\\":\\\"G\\\",\\\"Ğ\\\":\\\"G\\\",\\\"Ġ\\\":\\\"G\\\",\\\"Ģ\\\":\\\"G\\\",\\\"ĝ\\\":\\\"g\\\",\\\"ğ\\\":\\\"g\\\",\\\"ġ\\\":\\\"g\\\",\\\"ģ\\\":\\\"g\\\",\\\"Ĥ\\\":\\\"H\\\",\\\"Ħ\\\":\\\"H\\\",\\\"ĥ\\\":\\\"h\\\",\\\"ħ\\\":\\\"h\\\",\\\"Ĩ\\\":\\\"I\\\",\\\"Ī\\\":\\\"I\\\",\\\"Ĭ\\\":\\\"I\\\",\\\"Į\\\":\\\"I\\\",\\\"İ\\\":\\\"I\\\",\\\"ĩ\\\":\\\"i\\\",\\\"ī\\\":\\\"i\\\",\\\"ĭ\\\":\\\"i\\\",\\\"į\\\":\\\"i\\\",\\\"ı\\\":\\\"i\\\",\\\"Ĵ\\\":\\\"J\\\",\\\"ĵ\\\":\\\"j\\\",\\\"Ķ\\\":\\\"K\\\",\\\"ķ\\\":\\\"k\\\",\\\"ĸ\\\":\\\"k\\\",\\\"Ĺ\\\":\\\"L\\\",\\\"Ļ\\\":\\\"L\\\",\\\"Ľ\\\":\\\"L\\\",\\\"Ŀ\\\":\\\"L\\\",\\\"Ł\\\":\\\"L\\\",\\\"ĺ\\\":\\\"l\\\",\\\"ļ\\\":\\\"l\\\",\\\"ľ\\\":\\\"l\\\",\\\"ŀ\\\":\\\"l\\\",\\\"ł\\\":\\\"l\\\",\\\"Ń\\\":\\\"N\\\",\\\"Ņ\\\":\\\"N\\\",\\\"Ň\\\":\\\"N\\\",\\\"Ŋ\\\":\\\"N\\\",\\\"ń\\\":\\\"n\\\",\\\"ņ\\\":\\\"n\\\",\\\"ň\\\":\\\"n\\\",\\\"ŋ\\\":\\\"n\\\",\\\"Ō\\\":\\\"O\\\",\\\"Ŏ\\\":\\\"O\\\",\\\"Ő\\\":\\\"O\\\",\\\"ō\\\":\\\"o\\\",\\\"ŏ\\\":\\\"o\\\",\\\"ő\\\":\\\"o\\\",\\\"Ŕ\\\":\\\"R\\\",\\\"Ŗ\\\":\\\"R\\\",\\\"Ř\\\":\\\"R\\\",\\\"ŕ\\\":\\\"r\\\",\\\"ŗ\\\":\\\"r\\\",\\\"ř\\\":\\\"r\\\",\\\"Ś\\\":\\\"S\\\",\\\"Ŝ\\\":\\\"S\\\",\\\"Ş\\\":\\\"S\\\",\\\"Š\\\":\\\"S\\\",\\\"ś\\\":\\\"s\\\",\\\"ŝ\\\":\\\"s\\\",\\\"ş\\\":\\\"s\\\",\\\"š\\\":\\\"s\\\",\\\"Ţ\\\":\\\"T\\\",\\\"Ť\\\":\\\"T\\\",\\\"Ŧ\\\":\\\"T\\\",\\\"ţ\\\":\\\"t\\\",\\\"ť\\\":\\\"t\\\",\\\"ŧ\\\":\\\"t\\\",\\\"Ũ\\\":\\\"U\\\",\\\"Ū\\\":\\\"U\\\",\\\"Ŭ\\\":\\\"U\\\",\\\"Ů\\\":\\\"U\\\",\\\"Ű\\\":\\\"U\\\",\\\"Ų\\\":\\\"U\\\",\\\"ũ\\\":\\\"u\\\",\\\"ū\\\":\\\"u\\\",\\\"ŭ\\\":\\\"u\\\",\\\"ů\\\":\\\"u\\\",\\\"ű\\\":\\\"u\\\",\\\"ų\\\":\\\"u\\\",\\\"Ŵ\\\":\\\"W\\\",\\\"ŵ\\\":\\\"w\\\",\\\"Ŷ\\\":\\\"Y\\\",\\\"ŷ\\\":\\\"y\\\",\\\"Ÿ\\\":\\\"Y\\\",\\\"Ź\\\":\\\"Z\\\",\\\"Ż\\\":\\\"Z\\\",\\\"Ž\\\":\\\"Z\\\",\\\"ź\\\":\\\"z\\\",\\\"ż\\\":\\\"z\\\",\\\"ž\\\":\\\"z\\\",\\\"IJ\\\":\\\"IJ\\\",\\\"ij\\\":\\\"ij\\\",\\\"Œ\\\":\\\"Oe\\\",\\\"œ\\\":\\\"oe\\\",\\\"ʼn\\\":\\\"'n\\\",\\\"ſ\\\":\\\"s\\\"},Qe={\\\"&\\\":\\\"&\\\",\\\"<\\\":\\\"<\\\",\\\">\\\":\\\">\\\",'\\\"':\\\""\\\",\\\"'\\\":\\\"'\\\"},tn={\\\"&\\\":\\\"&\\\",\\\"<\\\":\\\"<\\\",\\\">\\\":\\\">\\\",\\\""\\\":'\\\"',\\\"'\\\":\\\"'\\\"},en={\\\"\\\\\\\\\\\":\\\"\\\\\\\\\\\",\\\"'\\\":\\\"'\\\",\\\"\\\\n\\\":\\\"n\\\",\\\"\\\\r\\\":\\\"r\\\",\\\"\\\\u2028\\\":\\\"u2028\\\",\\\"\\\\u2029\\\":\\\"u2029\\\"},nn=parseFloat,rn=parseInt,on=\\\"object\\\"==typeof t&&t&&t.Object===Object&&t,sn=\\\"object\\\"==typeof self&&self&&self.Object===Object&&self,an=on||sn||Function(\\\"return this\\\")(),un=e&&!e.nodeType&&e,ln=un&&\\\"object\\\"==typeof r&&r&&!r.nodeType&&r,cn=ln&&ln.exports===un,hn=cn&&on.process,fn=function(){try{var t=ln&&ln.require&&ln.require(\\\"util\\\").types;return t||hn&&hn.binding&&hn.binding(\\\"util\\\")}catch(e){}}(),gn=fn&&fn.isArrayBuffer,dn=fn&&fn.isDate,pn=fn&&fn.isMap,vn=fn&&fn.isRegExp,yn=fn&&fn.isSet,mn=fn&&fn.isTypedArray;function xn(t,e,n){switch(n.length){case 0:return t.call(e);case 1:return t.call(e,n[0]);case 2:return t.call(e,n[0],n[1]);case 3:return t.call(e,n[0],n[1],n[2])}return t.apply(e,n)}function En(t,e,n,r){var i=-1,o=null==t?0:t.length;while(++i-1}function Sn(t,e,n){var r=-1,i=null==t?0:t.length;while(++r-1);return n}function $n(t,e){var n=t.length;while(n--&&kn(e,t[n],0)>-1);return n}function Qn(t,e){var n=t.length,r=0;while(n--)t[n]===e&&++r;return r}var tr=zn($e),er=zn(Qe);function nr(t){return\\\"\\\\\\\\\\\"+en[t]}function rr(t,e){return null==t?o:t[e]}function ir(t){return Ye.test(t)}function or(t){return We.test(t)}function sr(t){var e,n=[];while(!(e=t.next()).done)n.push(e.value);return n}function ar(t){var e=-1,n=Array(t.size);return t.forEach(function(t,r){n[++e]=[r,t]}),n}function ur(t,e){return function(n){return t(e(n))}}function lr(t,e){var n=-1,r=t.length,i=0,o=[];while(++n-1}function qr(t,e){var n=this.__data__,r=ui(n,t);return r<0?(++this.size,n.push([t,e])):n[r][1]=e,this}function Br(t){var e=-1,n=null==t?0:t.length;this.clear();while(++e=e?t:e)),t}function pi(t,e,n,r,i,s){var a,u=e&g,l=e&d,c=e&p;if(n&&(a=i?n(t,r,i,s):n(t)),a!==o)return a;if(!bc(t))return t;var h=sc(t);if(h){if(a=Qs(t),!u)return ns(t,a)}else{var f=Js(t),v=f==Z||f==K;if(hc(t))return Yo(t,u);if(f==et||f==j||v&&!i){if(a=l||v?{}:ta(t),!u)return l?os(t,hi(a,t)):is(t,ci(a,t))}else{if(!Ke[f])return i?t:{};a=ea(t,f,u)}}s||(s=new Zr);var y=s.get(t);if(y)return y;s.set(t,a),Dc(t)?t.forEach(function(r){a.add(pi(r,e,n,r,t,s))}):Nc(t)&&t.forEach(function(r,i){a.set(i,pi(r,e,n,i,t,s))});var m=c?l?Gs:ks:l?wh:Eh,x=h?o:m(t);return wn(x||t,function(r,i){x&&(i=r,r=t[i]),ai(a,i,pi(r,e,n,i,t,s))}),a}function vi(t){var e=Eh(t);return function(n){return yi(n,t,e)}}function yi(t,e,n){var r=n.length;if(null==t)return!r;t=ne(t);while(r--){var i=n[r],s=e[i],a=t[i];if(a===o&&!(i in t)||!s(a))return!1}return!0}function mi(t,e,n){if(\\\"function\\\"!=typeof t)throw new oe(l);return Ia(function(){t.apply(o,n)},e)}function xi(t,e,n,r){var i=-1,o=Cn,s=!0,u=t.length,l=[],c=e.length;if(!u)return l;n&&(e=Mn(e,Hn(n))),r?(o=Sn,s=!1):e.length>=a&&(o=Zn,s=!1,e=new Wr(e));t:while(++ii?0:i+n),r=r===o||r>i?i:Yc(r),r<0&&(r+=i),r=n>r?0:Wc(r);while(n0&&n(a)?e>1?Si(a,e-1,n,r,i):_n(i,a):r||(i[i.length]=a)}return i}var Mi=ls(),_i=ls(!0);function Li(t,e){return t&&Mi(t,e,Eh)}function Pi(t,e){return t&&_i(t,e,Eh)}function Ri(t,e){return Nn(e,function(e){return xc(t[e])})}function Ti(t,e){e=zo(e,t);var n=0,r=e.length;while(null!=t&&ne}function Fi(t,e){return null!=t&&he.call(t,e)}function ki(t,e){return null!=t&&e in ne(t)}function Gi(t,e,n){return t>=Be(e,n)&&t=120&&f.length>=120)?new Wr(u&&f):o}f=t[0];var g=-1,d=l[0];t:while(++g-1)a!==t&&Ce.call(a,u,1),Ce.call(t,u,1)}return t}function po(t,e){var n=t?e.length:0,r=n-1;while(n--){var i=e[n];if(n==r||i!==o){var o=i;ia(i)?Ce.call(t,i,1):Ao(t,i)}}return t}function vo(t,e){return t+Ae(Ye()*(e-t+1))}function yo(t,e,r,i){var o=-1,s=qe(Oe((e-t)/(r||1)),0),a=n(s);while(s--)a[i?s:++o]=t,t+=r;return a}function mo(t,e){var n=\\\"\\\";if(!t||e<1||e>F)return n;do{e%2&&(n+=t),e=Ae(e/2),e&&(t+=t)}while(e);return n}function xo(t,e){return Na(ma(t,e,Lf),t+\\\"\\\")}function Eo(t){return ri(Vh(t))}function wo(t,e){var n=Vh(t);return Ma(n,di(e,0,n.length))}function bo(t,e,n,r){if(!bc(t))return t;e=zo(e,t);var i=-1,s=e.length,a=s-1,u=t;while(null!=u&&++io?0:o+e),r=r>o?o:r,r<0&&(r+=o),o=e>r?0:r-e>>>0,e>>>=0;var s=n(o);while(++i>>1,s=t[o];null!==s&&!kc(s)&&(n?s<=e:s=a){var c=e?null:Ms(t);if(c)return cr(c);s=!1,i=Zn,l=new Wr}else l=e?[]:u;t:while(++r=r?t:So(t,e,n)}var Xo=Pe||function(t){return an.clearTimeout(t)};function Yo(t,e){if(e)return t.slice();var n=t.length,r=we?we(n):new t.constructor(n);return t.copy(r),r}function Wo(t){var e=new t.constructor(t.byteLength);return new Ee(e).set(new Ee(t)),e}function Ho(t,e){var n=e?Wo(t.buffer):t.buffer;return new t.constructor(n,t.byteOffset,t.byteLength)}function Jo(t){var e=new t.constructor(t.source,Yt.exec(t));return e.lastIndex=t.lastIndex,e}function Zo(t){return yr?ne(yr.call(t)):{}}function Ko(t,e){var n=e?Wo(t.buffer):t.buffer;return new t.constructor(n,t.byteOffset,t.length)}function $o(t,e){if(t!==e){var n=t!==o,r=null===t,i=t===t,s=kc(t),a=e!==o,u=null===e,l=e===e,c=kc(e);if(!u&&!c&&!s&&t>e||s&&a&&l&&!u&&!c||r&&a&&l||!n&&l||!i)return 1;if(!r&&!s&&!c&&t=a)return u;var l=n[r];return u*(\\\"desc\\\"==l?-1:1)}}return t.index-e.index}function ts(t,e,r,i){var o=-1,s=t.length,a=r.length,u=-1,l=e.length,c=qe(s-a,0),h=n(l+c),f=!i;while(++u1?n[i-1]:o,a=i>2?n[2]:o;s=t.length>3&&\\\"function\\\"==typeof s?(i--,s):o,a&&oa(n[0],n[1],a)&&(s=i<3?o:s,i=1),e=ne(e);while(++r-1?i[s?e[a]:a]:o}}function vs(t){return Fs(function(e){var n=e.length,r=n,i=Nr.prototype.thru;t&&e.reverse();while(r--){var s=e[r];if(\\\"function\\\"!=typeof s)throw new oe(l);if(i&&!a&&\\\"wrapper\\\"==qs(s))var a=new Nr([],!0)}r=a?r:n;while(++r1&&m.reverse(),f&&cu))return!1;var c=s.get(t);if(c&&s.get(e))return c==e;var h=-1,f=!0,g=n&y?new Wr:o;s.set(t,e),s.set(e,t);while(++h1?\\\"& \\\":\\\"\\\")+e[r],e=e.join(n>2?\\\", \\\":\\\" \\\"),t.replace(qt,\\\"{\\\\n/* [wrapped with \\\"+e+\\\"] */\\\\n\\\")}function ra(t){return sc(t)||oc(t)||!!(Se&&t&&t[Se])}function ia(t,e){var n=typeof t;return e=null==e?F:e,!!e&&(\\\"number\\\"==n||\\\"symbol\\\"!=n&&Kt.test(t))&&t>-1&&t%1==0&&t0){if(++e>=P)return arguments[0]}else e=0;return t.apply(o,arguments)}}function Ma(t,e){var n=-1,r=t.length,i=r-1;e=e===o?r:e;while(++n1?t[e-1]:o;return n=\\\"function\\\"==typeof n?(t.pop(),n):o,Au(t,n)});function ju(t){var e=Er(t);return e.__chain__=!0,e}function Uu(t,e){return e(t),t}function Xu(t,e){return e(t)}var Yu=Fs(function(t){var e=t.length,n=e?t[0]:0,r=this.__wrapped__,i=function(e){return gi(e,t)};return!(e>1||this.__actions__.length)&&r instanceof Cr&&ia(n)?(r=r.slice(n,+n+(e?1:0)),r.__actions__.push({func:Xu,args:[i],thisArg:o}),new Nr(r,this.__chain__).thru(function(t){return e&&!t.length&&t.push(o),t})):this.thru(i)});function Wu(){return ju(this)}function Hu(){return new Nr(this.value(),this.__chain__)}function Ju(){this.__values__===o&&(this.__values__=Uc(this.value()));var t=this.__index__>=this.__values__.length,e=t?o:this.__values__[this.__index__++];return{done:t,value:e}}function Zu(){return this}function Ku(t){var e,n=this;while(n instanceof Ir){var r=Ta(n);r.__index__=0,r.__values__=o,e?i.__wrapped__=r:e=r;var i=r;n=n.__wrapped__}return i.__wrapped__=t,e}function $u(){var t=this.__wrapped__;if(t instanceof Cr){var e=t;return this.__actions__.length&&(e=new Cr(this)),e=e.reverse(),e.__actions__.push({func:Xu,args:[fu],thisArg:o}),new Nr(e,this.__chain__)}return this.thru(fu)}function Qu(){return ko(this.__wrapped__,this.__actions__)}var tl=ss(function(t,e,n){he.call(t,n)?++t[n]:fi(t,n,1)});function el(t,e,n){var r=sc(t)?In:bi;return n&&oa(t,e,n)&&(e=o),r(t,zs(e,3))}function nl(t,e){var n=sc(t)?Nn:Ci;return n(t,zs(e,3))}var rl=ps(Ua),il=ps(Xa);function ol(t,e){return Si(dl(t,e),1)}function sl(t,e){return Si(dl(t,e),D)}function al(t,e,n){return n=n===o?1:Yc(n),Si(dl(t,e),n)}function ul(t,e){var n=sc(t)?wn:Ei;return n(t,zs(e,3))}function ll(t,e){var n=sc(t)?bn:wi;return n(t,zs(e,3))}var cl=ss(function(t,e,n){he.call(t,n)?t[n].push(e):fi(t,n,[e])});function hl(t,e,n,r){t=uc(t)?t:Vh(t),n=n&&!r?Yc(n):0;var i=t.length;return n<0&&(n=qe(i+n,0)),Fc(t)?n<=i&&t.indexOf(e,n)>-1:!!i&&kn(t,e,n)>-1}var fl=xo(function(t,e,r){var i=-1,o=\\\"function\\\"==typeof e,s=uc(t)?n(t.length):[];return Ei(t,function(t){s[++i]=o?xn(e,t,r):Bi(t,e,r)}),s}),gl=ss(function(t,e,n){fi(t,n,e)});function dl(t,e){var n=sc(t)?Mn:ro;return n(t,zs(e,3))}function pl(t,e,n,r){return null==t?[]:(sc(e)||(e=null==e?[]:[e]),n=r?o:n,sc(n)||(n=null==n?[]:[n]),lo(t,e,n))}var vl=ss(function(t,e,n){t[n?0:1].push(e)},function(){return[[],[]]});function yl(t,e,n){var r=sc(t)?Ln:jn,i=arguments.length<3;return r(t,zs(e,4),n,i,Ei)}function ml(t,e,n){var r=sc(t)?Pn:jn,i=arguments.length<3;return r(t,zs(e,4),n,i,wi)}function xl(t,e){var n=sc(t)?Nn:Ci;return n(t,Vl(zs(e,3)))}function El(t){var e=sc(t)?ri:Eo;return e(t)}function wl(t,e,n){e=(n?oa(t,e,n):e===o)?1:Yc(e);var r=sc(t)?ii:wo;return r(t,e)}function bl(t){var e=sc(t)?oi:Co;return e(t)}function Il(t){if(null==t)return 0;if(uc(t))return Fc(t)?dr(t):t.length;var e=Js(t);return e==$||e==ot?t.size:to(t).length}function Nl(t,e,n){var r=sc(t)?Rn:Mo;return n&&oa(t,e,n)&&(e=o),r(t,zs(e,3))}var Cl=xo(function(t,e){if(null==t)return[];var n=e.length;return n>1&&oa(t,e[0],e[1])?e=[]:n>2&&oa(e[0],e[1],e[2])&&(e=[e[0]]),lo(t,Si(e,1),[])}),Sl=Re||function(){return an.Date.now()};function Ml(t,e){if(\\\"function\\\"!=typeof e)throw new oe(l);return t=Yc(t),function(){if(--t<1)return e.apply(this,arguments)}}function _l(t,e,n){return e=n?o:e,e=t&&null==e?t.length:e,Ls(t,C,o,o,o,o,e)}function Ll(t,e){var n;if(\\\"function\\\"!=typeof e)throw new oe(l);return t=Yc(t),function(){return--t>0&&(n=e.apply(this,arguments)),t<=1&&(e=o),n}}var Pl=xo(function(t,e,n){var r=m;if(n.length){var i=lr(n,Bs(Pl));r|=I}return Ls(t,r,e,n,i)}),Rl=xo(function(t,e,n){var r=m|x;if(n.length){var i=lr(n,Bs(Rl));r|=I}return Ls(e,r,t,n,i)});function Tl(t,e,n){e=n?o:e;var r=Ls(t,w,o,o,o,o,o,e);return r.placeholder=Tl.placeholder,r}function Ol(t,e,n){e=n?o:e;var r=Ls(t,b,o,o,o,o,o,e);return r.placeholder=Ol.placeholder,r}function Al(t,e,n){var r,i,s,a,u,c,h=0,f=!1,g=!1,d=!0;if(\\\"function\\\"!=typeof t)throw new oe(l);function p(e){var n=r,s=i;return r=i=o,h=e,a=t.apply(s,n),a}function v(t){return h=t,u=Ia(x,e),f?p(t):a}function y(t){var n=t-c,r=t-h,i=e-n;return g?Be(i,s-r):i}function m(t){var n=t-c,r=t-h;return c===o||n>=e||n<0||g&&r>=s}function x(){var t=Sl();if(m(t))return E(t);u=Ia(x,y(t))}function E(t){return u=o,d&&r?p(t):(r=i=o,a)}function w(){u!==o&&Xo(u),h=0,r=c=i=u=o}function b(){return u===o?a:E(Sl())}function I(){var t=Sl(),n=m(t);if(r=arguments,i=this,c=t,n){if(u===o)return v(c);if(g)return Xo(u),u=Ia(x,e),p(c)}return u===o&&(u=Ia(x,e)),a}return e=Hc(e)||0,bc(n)&&(f=!!n.leading,g=\\\"maxWait\\\"in n,s=g?qe(Hc(n.maxWait)||0,e):s,d=\\\"trailing\\\"in n?!!n.trailing:d),I.cancel=w,I.flush=b,I}var Dl=xo(function(t,e){return mi(t,1,e)}),Fl=xo(function(t,e,n){return mi(t,Hc(e)||0,n)});function kl(t){return Ls(t,M)}function Gl(t,e){if(\\\"function\\\"!=typeof t||null!=e&&\\\"function\\\"!=typeof e)throw new oe(l);var n=function(){var r=arguments,i=e?e.apply(this,r):r[0],o=n.cache;if(o.has(i))return o.get(i);var s=t.apply(this,r);return n.cache=o.set(i,s)||o,s};return n.cache=new(Gl.Cache||Br),n}function Vl(t){if(\\\"function\\\"!=typeof t)throw new oe(l);return function(){var e=arguments;switch(e.length){case 0:return!t.call(this);case 1:return!t.call(this,e[0]);case 2:return!t.call(this,e[0],e[1]);case 3:return!t.call(this,e[0],e[1],e[2])}return!t.apply(this,e)}}function ql(t){return Ll(2,t)}Gl.Cache=Br;var Bl=jo(function(t,e){e=1==e.length&&sc(e[0])?Mn(e[0],Hn(zs())):Mn(Si(e,1),Hn(zs()));var n=e.length;return xo(function(r){var i=-1,o=Be(r.length,n);while(++i=e}),oc=zi(function(){return arguments}())?zi:function(t){return Ic(t)&&he.call(t,\\\"callee\\\")&&!Ne.call(t,\\\"callee\\\")},sc=n.isArray,ac=gn?Hn(gn):ji;function uc(t){return null!=t&&wc(t.length)&&!xc(t)}function lc(t){return Ic(t)&&uc(t)}function cc(t){return!0===t||!1===t||Ic(t)&&Ai(t)==Y}var hc=Fe||Wf,fc=dn?Hn(dn):Ui;function gc(t){return Ic(t)&&1===t.nodeType&&!Tc(t)}function dc(t){if(null==t)return!0;if(uc(t)&&(sc(t)||\\\"string\\\"==typeof t||\\\"function\\\"==typeof t.splice||hc(t)||Gc(t)||oc(t)))return!t.length;var e=Js(t);if(e==$||e==ot)return!t.size;if(ha(t))return!to(t).length;for(var n in t)if(he.call(t,n))return!1;return!0}function pc(t,e){return Xi(t,e)}function vc(t,e,n){n=\\\"function\\\"==typeof n?n:o;var r=n?n(t,e):o;return r===o?Xi(t,e,o,n):!!r}function yc(t){if(!Ic(t))return!1;var e=Ai(t);return e==J||e==H||\\\"string\\\"==typeof t.message&&\\\"string\\\"==typeof t.name&&!Tc(t)}function mc(t){return\\\"number\\\"==typeof t&&ke(t)}function xc(t){if(!bc(t))return!1;var e=Ai(t);return e==Z||e==K||e==X||e==rt}function Ec(t){return\\\"number\\\"==typeof t&&t==Yc(t)}function wc(t){return\\\"number\\\"==typeof t&&t>-1&&t%1==0&&t<=F}function bc(t){var e=typeof t;return null!=t&&(\\\"object\\\"==e||\\\"function\\\"==e)}function Ic(t){return null!=t&&\\\"object\\\"==typeof t}var Nc=pn?Hn(pn):Wi;function Cc(t,e){return t===e||Hi(t,e,Us(e))}function Sc(t,e,n){return n=\\\"function\\\"==typeof n?n:o,Hi(t,e,Us(e),n)}function Mc(t){return Rc(t)&&t!=+t}function _c(t){if(ca(t))throw new i(u);return Ji(t)}function Lc(t){return null===t}function Pc(t){return null==t}function Rc(t){return\\\"number\\\"==typeof t||Ic(t)&&Ai(t)==Q}function Tc(t){if(!Ic(t)||Ai(t)!=et)return!1;var e=be(t);if(null===e)return!0;var n=he.call(e,\\\"constructor\\\")&&e.constructor;return\\\"function\\\"==typeof n&&n instanceof n&&ce.call(n)==pe}var Oc=vn?Hn(vn):Zi;function Ac(t){return Ec(t)&&t>=-F&&t<=F}var Dc=yn?Hn(yn):Ki;function Fc(t){return\\\"string\\\"==typeof t||!sc(t)&&Ic(t)&&Ai(t)==st}function kc(t){return\\\"symbol\\\"==typeof t||Ic(t)&&Ai(t)==at}var Gc=mn?Hn(mn):$i;function Vc(t){return t===o}function qc(t){return Ic(t)&&Js(t)==lt}function Bc(t){return Ic(t)&&Ai(t)==ct}var zc=Ns(no),jc=Ns(function(t,e){return t<=e});function Uc(t){if(!t)return[];if(uc(t))return Fc(t)?pr(t):ns(t);if(Me&&t[Me])return sr(t[Me]());var e=Js(t),n=e==$?ar:e==ot?cr:Vh;return n(t)}function Xc(t){if(!t)return 0===t?t:0;if(t=Hc(t),t===D||t===-D){var e=t<0?-1:1;return e*k}return t===t?t:0}function Yc(t){var e=Xc(t),n=e%1;return e===e?n?e-n:e:0}function Wc(t){return t?di(Yc(t),0,V):0}function Hc(t){if(\\\"number\\\"==typeof t)return t;if(kc(t))return G;if(bc(t)){var e=\\\"function\\\"==typeof t.valueOf?t.valueOf():t;t=bc(e)?e+\\\"\\\":e}if(\\\"string\\\"!=typeof t)return 0===t?t:+t;t=t.replace(kt,\\\"\\\");var n=Ht.test(t);return n||Zt.test(t)?rn(t.slice(2),n?2:8):Wt.test(t)?G:+t}function Jc(t){return rs(t,wh(t))}function Zc(t){return t?di(Yc(t),-F,F):0===t?t:0}function Kc(t){return null==t?\\\"\\\":To(t)}var $c=as(function(t,e){if(ha(e)||uc(e))rs(e,Eh(e),t);else for(var n in e)he.call(e,n)&&ai(t,n,e[n])}),Qc=as(function(t,e){rs(e,wh(e),t)}),th=as(function(t,e,n,r){rs(e,wh(e),t,r)}),eh=as(function(t,e,n,r){rs(e,Eh(e),t,r)}),nh=Fs(gi);function rh(t,e){var n=br(t);return null==e?n:ci(n,e)}var ih=xo(function(t,e){t=ne(t);var n=-1,r=e.length,i=r>2?e[2]:o;i&&oa(e[0],e[1],i)&&(r=1);while(++n1),e}),rs(t,Gs(t),n),r&&(n=pi(n,g|d|p,Ts));var i=e.length;while(i--)Ao(n,e[i]);return n});function Mh(t,e){return Lh(t,Vl(zs(e)))}var _h=Fs(function(t,e){return null==t?{}:co(t,e)});function Lh(t,e){if(null==t)return{};var n=Mn(Gs(t),function(t){return[t]});return e=zs(e),ho(t,n,function(t,n){return e(t,n[0])})}function Ph(t,e,n){e=zo(e,t);var r=-1,i=e.length;i||(i=1,t=o);while(++re){var r=t;t=e,e=r}if(n||t%1||e%1){var i=Ye();return Be(t+i*(e-t+nn(\\\"1e-\\\"+((i+\\\"\\\").length-1))),e)}return vo(t,e)}var Uh=fs(function(t,e,n){return e=e.toLowerCase(),t+(n?Xh(e):e)});function Xh(t){return xf(Kc(t).toLowerCase())}function Yh(t){return t=Kc(t),t&&t.replace($t,tr).replace(je,\\\"\\\")}function Wh(t,e,n){t=Kc(t),e=To(e);var r=t.length;n=n===o?r:di(Yc(n),0,r);var i=n;return n-=e.length,n>=0&&t.slice(n,i)==e}function Hh(t){return t=Kc(t),t&&_t.test(t)?t.replace(St,er):t}function Jh(t){return t=Kc(t),t&&Ft.test(t)?t.replace(Dt,\\\"\\\\\\\\$&\\\"):t}var Zh=fs(function(t,e,n){return t+(n?\\\"-\\\":\\\"\\\")+e.toLowerCase()}),Kh=fs(function(t,e,n){return t+(n?\\\" \\\":\\\"\\\")+e.toLowerCase()}),$h=hs(\\\"toLowerCase\\\");function Qh(t,e,n){t=Kc(t),e=Yc(e);var r=e?dr(t):0;if(!e||r>=e)return t;var i=(e-r)/2;return ws(Ae(i),n)+t+ws(Oe(i),n)}function tf(t,e,n){t=Kc(t),e=Yc(e);var r=e?dr(t):0;return e&&r>>0,n?(t=Kc(t),t&&(\\\"string\\\"==typeof e||null!=e&&!Oc(e))&&(e=To(e),!e&&ir(t))?Uo(pr(t),0,n):t.split(e,n)):[]}var uf=fs(function(t,e,n){return t+(n?\\\" \\\":\\\"\\\")+xf(e)});function lf(t,e,n){return t=Kc(t),n=null==n?0:di(Yc(n),0,t.length),e=To(e),t.slice(n,n+e.length)==e}function cf(t,e,n){var r=Er.templateSettings;n&&oa(t,e,n)&&(e=o),t=Kc(t),e=th({},e,r,Ps);var i,s,a=th({},e.imports,r.imports,Ps),u=Eh(a),l=Jn(a,u),c=0,h=e.interpolate||Qt,f=\\\"__p += '\\\",g=re((e.escape||Qt).source+\\\"|\\\"+h.source+\\\"|\\\"+(h===Rt?Xt:Qt).source+\\\"|\\\"+(e.evaluate||Qt).source+\\\"|$\\\",\\\"g\\\"),d=\\\"//# sourceURL=\\\"+(he.call(e,\\\"sourceURL\\\")?(e.sourceURL+\\\"\\\").replace(/[\\\\r\\\\n]/g,\\\" \\\"):\\\"lodash.templateSources[\\\"+ ++Je+\\\"]\\\")+\\\"\\\\n\\\";t.replace(g,function(e,n,r,o,a,u){return r||(r=o),f+=t.slice(c,u).replace(te,nr),n&&(i=!0,f+=\\\"' +\\\\n__e(\\\"+n+\\\") +\\\\n'\\\"),a&&(s=!0,f+=\\\"';\\\\n\\\"+a+\\\";\\\\n__p += '\\\"),r&&(f+=\\\"' +\\\\n((__t = (\\\"+r+\\\")) == null ? '' : __t) +\\\\n'\\\"),c=u+e.length,e}),f+=\\\"';\\\\n\\\";var p=he.call(e,\\\"variable\\\")&&e.variable;p||(f=\\\"with (obj) {\\\\n\\\"+f+\\\"\\\\n}\\\\n\\\"),f=(s?f.replace(bt,\\\"\\\"):f).replace(It,\\\"$1\\\").replace(Nt,\\\"$1;\\\"),f=\\\"function(\\\"+(p||\\\"obj\\\")+\\\") {\\\\n\\\"+(p?\\\"\\\":\\\"obj || (obj = {});\\\\n\\\")+\\\"var __t, __p = ''\\\"+(i?\\\", __e = _.escape\\\":\\\"\\\")+(s?\\\", __j = Array.prototype.join;\\\\nfunction print() { __p += __j.call(arguments, '') }\\\\n\\\":\\\";\\\\n\\\")+f+\\\"return __p\\\\n}\\\";var v=wf(function(){return jt(u,d+\\\"return \\\"+f).apply(o,l)});if(v.source=f,yc(v))throw v;return v}function hf(t){return Kc(t).toLowerCase()}function ff(t){return Kc(t).toUpperCase()}function gf(t,e,n){if(t=Kc(t),t&&(n||e===o))return t.replace(kt,\\\"\\\");if(!t||!(e=To(e)))return t;var r=pr(t),i=pr(e),s=Kn(r,i),a=$n(r,i)+1;return Uo(r,s,a).join(\\\"\\\")}function df(t,e,n){if(t=Kc(t),t&&(n||e===o))return t.replace(Vt,\\\"\\\");if(!t||!(e=To(e)))return t;var r=pr(t),i=$n(r,pr(e))+1;return Uo(r,0,i).join(\\\"\\\")}function pf(t,e,n){if(t=Kc(t),t&&(n||e===o))return t.replace(Gt,\\\"\\\");if(!t||!(e=To(e)))return t;var r=pr(t),i=Kn(r,pr(e));return Uo(r,i).join(\\\"\\\")}function vf(t,e){var n=_,r=L;if(bc(e)){var i=\\\"separator\\\"in e?e.separator:i;n=\\\"length\\\"in e?Yc(e.length):n,r=\\\"omission\\\"in e?To(e.omission):r}t=Kc(t);var s=t.length;if(ir(t)){var a=pr(t);s=a.length}if(n>=s)return t;var u=n-dr(r);if(u<1)return r;var l=a?Uo(a,0,u).join(\\\"\\\"):t.slice(0,u);if(i===o)return l+r;if(a&&(u+=l.length-u),Oc(i)){if(t.slice(u).search(i)){var c,h=l;i.global||(i=re(i.source,Kc(Yt.exec(i))+\\\"g\\\")),i.lastIndex=0;while(c=i.exec(h))var f=c.index;l=l.slice(0,f===o?u:f)}}else if(t.indexOf(To(i),u)!=u){var g=l.lastIndexOf(i);g>-1&&(l=l.slice(0,g))}return l+r}function yf(t){return t=Kc(t),t&&Mt.test(t)?t.replace(Ct,vr):t}var mf=fs(function(t,e,n){return t+(n?\\\" \\\":\\\"\\\")+e.toUpperCase()}),xf=hs(\\\"toUpperCase\\\");function Ef(t,e,n){return t=Kc(t),e=n?o:e,e===o?or(t)?xr(t):An(t):t.match(e)||[]}var wf=xo(function(t,e){try{return xn(t,o,e)}catch(n){return yc(n)?n:new i(n)}}),bf=Fs(function(t,e){return wn(e,function(e){e=La(e),fi(t,e,Pl(t[e],t))}),t});function If(t){var e=null==t?0:t.length,n=zs();return t=e?Mn(t,function(t){if(\\\"function\\\"!=typeof t[1])throw new oe(l);return[n(t[0]),t[1]]}):[],xo(function(n){var r=-1;while(++rF)return[];var n=V,r=Be(t,V);e=zs(e),t-=V;var i=Yn(r,e);while(++n0||e<0)?new Cr(n):(t<0?n=n.takeRight(-t):t&&(n=n.drop(t)),e!==o&&(e=Yc(e),n=e<0?n.dropRight(-e):n.take(e-t)),n)},Cr.prototype.takeRightWhile=function(t){return this.reverse().takeWhile(t).reverse()},Cr.prototype.toArray=function(){return this.take(V)},Li(Cr.prototype,function(t,e){var n=/^(?:filter|find|map|reject)|While$/.test(e),r=/^(?:head|last)$/.test(e),i=Er[r?\\\"take\\\"+(\\\"last\\\"==e?\\\"Right\\\":\\\"\\\"):e],s=r||/^find/.test(e);i&&(Er.prototype[e]=function(){var e=this.__wrapped__,a=r?[1]:arguments,u=e instanceof Cr,l=a[0],c=u||sc(e),h=function(t){var e=i.apply(Er,_n([t],a));return r&&f?e[0]:e};c&&n&&\\\"function\\\"==typeof l&&1!=l.length&&(u=c=!1);var f=this.__chain__,g=!!this.__actions__.length,d=s&&!f,p=u&&!g;if(!s&&c){e=p?e:new Cr(this);var v=t.apply(e,a);return v.__actions__.push({func:Xu,args:[h],thisArg:o}),new Nr(v,f)}return d&&p?t.apply(this,a):(v=this.thru(h),d?r?v.value()[0]:v.value():v)})}),wn([\\\"pop\\\",\\\"push\\\",\\\"shift\\\",\\\"sort\\\",\\\"splice\\\",\\\"unshift\\\"],function(t){var e=se[t],n=/^(?:push|sort|unshift)$/.test(t)?\\\"tap\\\":\\\"thru\\\",r=/^(?:pop|shift)$/.test(t);Er.prototype[t]=function(){var t=arguments;if(r&&!this.__chain__){var i=this.value();return e.apply(sc(i)?i:[],t)}return this[n](function(n){return e.apply(sc(n)?n:[],t)})}}),Li(Cr.prototype,function(t,e){var n=Er[e];if(n){var r=n.name+\\\"\\\";he.call(ln,r)||(ln[r]=[]),ln[r].push({name:e,func:n})}}),ln[ys(o,x).name]=[{name:\\\"wrapper\\\",func:o}],Cr.prototype.clone=Sr,Cr.prototype.reverse=Mr,Cr.prototype.value=_r,Er.prototype.at=Yu,Er.prototype.chain=Wu,Er.prototype.commit=Hu,Er.prototype.next=Ju,Er.prototype.plant=Ku,Er.prototype.reverse=$u,Er.prototype.toJSON=Er.prototype.valueOf=Er.prototype.value=Qu,Er.prototype.first=Er.prototype.head,Me&&(Er.prototype[Me]=Zu),Er},wr=Er();an._=wr,i=function(){return wr}.call(e,n,e,r),i===o||(r.exports=i)}).call(this)}).call(this,n(\\\"c8ba\\\"),n(\\\"62e4\\\")(t))},\\\"2f75\\\":function(t,e,n){var r=n(\\\"8678\\\"),i=n(\\\"716c\\\").flattenEach,o=n(\\\"b24d\\\"),s=n(\\\"7752\\\");function a(t,e){switch(t.type){case\\\"Point\\\":switch(e.type){case\\\"Point\\\":return!g(t.coordinates,e.coordinates);case\\\"LineString\\\":return!u(e,t);case\\\"Polygon\\\":return!r(t,e)}break;case\\\"LineString\\\":switch(e.type){case\\\"Point\\\":return!u(t,e);case\\\"LineString\\\":return!l(t,e);case\\\"Polygon\\\":return!c(e,t)}break;case\\\"Polygon\\\":switch(e.type){case\\\"Point\\\":return!r(e,t);case\\\"LineString\\\":return!c(t,e);case\\\"Polygon\\\":return!h(e,t)}}}function u(t,e){for(var n=0;n0}function c(t,e){var n=o(e,s(t));return n.features.length>0}function h(t,e){for(var n=0;n=Math.abs(s)?o>0?t[0]<=n[0]&&n[0]<=e[0]:e[0]<=n[0]&&n[0]<=t[0]:s>0?t[1]<=n[1]&&n[1]<=e[1]:e[1]<=n[1]&&n[1]<=t[1])}function g(t,e){return t[0]===e[0]&&t[1]===e[1]}t.exports=function(t,e){var n;return i(t,function(t){i(e,function(e){if(!1===n)return!1;n=a(t.geometry,e.geometry)})}),n}},\\\"30b5\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\");function i(t){return encodeURIComponent(t).replace(/%40/gi,\\\"@\\\").replace(/%3A/gi,\\\":\\\").replace(/%24/g,\\\"$\\\").replace(/%2C/gi,\\\",\\\").replace(/%20/g,\\\"+\\\").replace(/%5B/gi,\\\"[\\\").replace(/%5D/gi,\\\"]\\\")}t.exports=function(t,e,n){if(!e)return t;var o;if(n)o=n(e);else if(r.isURLSearchParams(e))o=e.toString();else{var s=[];r.forEach(e,function(t,e){null!==t&&\\\"undefined\\\"!==typeof t&&(r.isArray(t)?e+=\\\"[]\\\":t=[t],r.forEach(t,function(t){r.isDate(t)?t=t.toISOString():r.isObject(t)&&(t=JSON.stringify(t)),s.push(i(e)+\\\"=\\\"+i(t))}))}),o=s.join(\\\"&\\\")}if(o){var a=t.indexOf(\\\"#\\\");-1!==a&&(t=t.slice(0,a)),t+=(-1===t.indexOf(\\\"?\\\")?\\\"?\\\":\\\"&\\\")+o}return t}},\\\"31ff\\\":function(t,e,n){var r=n(\\\"716c\\\").coordEach,i=n(\\\"f13f\\\");function o(t,e){return a(t,e,\\\"mercator\\\")}function s(t,e){return a(t,e,\\\"wgs84\\\")}function a(t,e,n){if(!t)throw new Error(\\\"geojson is required\\\");return!0!==e&&(t=i(t)),r(t,function(t){var e=\\\"mercator\\\"===n?u(t):l(t);t[0]=e[0],t[1]=e[1]}),t}function u(t){var e=Math.PI/180,n=6378137,r=20037508.342789244,i=Math.abs(t[0])<=180?t[0]:t[0]-360*c(t[0]),o=[n*i*e,n*Math.log(Math.tan(.25*Math.PI+.5*t[1]*e))];return o[0]>r&&(o[0]=r),o[0]<-r&&(o[0]=-r),o[1]>r&&(o[1]=r),o[1]<-r&&(o[1]=-r),o}function l(t){var e=180/Math.PI,n=6378137;return[t[0]*e/n,(.5*Math.PI-2*Math.atan(Math.exp(-t[1]/n)))*e]}function c(t){return t<0?-1:t>0?1:0}t.exports={toMercator:o,toWgs84:s}},\\\"324a\\\":function(t,e){t.exports=i,t.exports.parse=i,t.exports.stringify=o;var n=/[-+]?([0-9]*\\\\.[0-9]+|[0-9]+)([eE][-+]?[0-9]+)?/,r=new RegExp(\\\"^\\\"+n.source+\\\"(\\\\\\\\s\\\"+n.source+\\\"){1,}\\\");function i(t){var e=t.split(\\\";\\\"),n=e.pop(),i=(e.shift()||\\\"\\\").split(\\\"=\\\").pop(),o=0;function s(t){var e=n.substring(o).match(t);return e?(o+=e[0].length,e[0]):null}function a(t){return t&&i.match(/\\\\d+/)&&(t.crs={type:\\\"name\\\",properties:{name:\\\"urn:ogc:def:crs:EPSG::\\\"+i}}),t}function u(){s(/^\\\\s*/)}function l(){u();var t,e=0,n=[],i=[n],o=n;while(t=s(/^(\\\\()/)||s(/^(\\\\))/)||s(/^(,)/)||s(r)){if(\\\"(\\\"===t)i.push(o),o=[],i[i.length-1].push(o),e++;else if(\\\")\\\"===t){if(0===o.length)return null;if(o=i.pop(),!o)return null;if(e--,0===e)break}else if(\\\",\\\"===t)o=[],i[i.length-1].push(o);else{if(t.split(/\\\\s/g).some(isNaN))return null;Array.prototype.push.apply(o,t.split(/\\\\s/g).map(parseFloat))}u()}return 0!==e?null:n}function c(){var t,e,n=[];while(e=s(r)||s(/^(,)/))\\\",\\\"===e?(n.push(t),t=[]):e.split(/\\\\s/g).some(isNaN)||(t||(t=[]),Array.prototype.push.apply(t,e.split(/\\\\s/g).map(parseFloat))),u();return t?(n.push(t),n.length?n:null):null}function h(){if(!s(/^(point(\\\\sz)?)/i))return null;if(u(),!s(/^(\\\\()/))return null;var t=c();return t?(u(),s(/^(\\\\))/)?{type:\\\"Point\\\",coordinates:t[0]}:null):null}function f(){if(!s(/^(multipoint)/i))return null;u();var t=n.substring(n.indexOf(\\\"(\\\")+1,n.length-1).replace(/\\\\(/g,\\\"\\\").replace(/\\\\)/g,\\\"\\\");n=\\\"MULTIPOINT (\\\"+t+\\\")\\\";var e=l();return e?(u(),{type:\\\"MultiPoint\\\",coordinates:e}):null}function g(){if(!s(/^(multilinestring)/i))return null;u();var t=l();return t?(u(),{type:\\\"MultiLineString\\\",coordinates:t}):null}function d(){if(!s(/^(linestring(\\\\sz)?)/i))return null;if(u(),!s(/^(\\\\()/))return null;var t=c();return t&&s(/^(\\\\))/)?{type:\\\"LineString\\\",coordinates:t}:null}function p(){if(!s(/^(polygon(\\\\sz)?)/i))return null;u();var t=l();return t?{type:\\\"Polygon\\\",coordinates:t}:null}function v(){if(!s(/^(multipolygon)/i))return null;u();var t=l();return t?{type:\\\"MultiPolygon\\\",coordinates:t}:null}function y(){var t,e=[];if(!s(/^(geometrycollection)/i))return null;if(u(),!s(/^(\\\\()/))return null;while(t=m())e.push(t),u(),s(/^(,)/),u();return s(/^(\\\\))/)?{type:\\\"GeometryCollection\\\",geometries:e}:null}function m(){return h()||d()||p()||f()||g()||v()||y()}return a(m())}function o(t){function e(t){return t.join(\\\" \\\")}function n(t){return t.map(e).join(\\\", \\\")}function r(t){return t.map(n).map(s).join(\\\", \\\")}function i(t){return t.map(r).map(s).join(\\\", \\\")}function s(t){return\\\"(\\\"+t+\\\")\\\"}switch(\\\"Feature\\\"===t.type&&(t=t.geometry),t.type){case\\\"Point\\\":return\\\"POINT (\\\"+e(t.coordinates)+\\\")\\\";case\\\"LineString\\\":return\\\"LINESTRING (\\\"+n(t.coordinates)+\\\")\\\";case\\\"Polygon\\\":return\\\"POLYGON (\\\"+r(t.coordinates)+\\\")\\\";case\\\"MultiPoint\\\":return\\\"MULTIPOINT (\\\"+n(t.coordinates)+\\\")\\\";case\\\"MultiPolygon\\\":return\\\"MULTIPOLYGON (\\\"+i(t.coordinates)+\\\")\\\";case\\\"MultiLineString\\\":return\\\"MULTILINESTRING (\\\"+r(t.coordinates)+\\\")\\\";case\\\"GeometryCollection\\\":return\\\"GEOMETRYCOLLECTION (\\\"+t.geometries.map(o).join(\\\", \\\")+\\\")\\\";default:throw new Error(\\\"stringify requires a valid GeoJSON Feature or geometry object as input\\\")}}},3260:function(t,e){function n(t){var e=[];for(var n in t)e.push(n);return e}e=t.exports=\\\"function\\\"===typeof Object.keys?Object.keys:n,e.shim=n},\\\"32e9\\\":function(t,e,n){var r=n(\\\"86cc\\\"),i=n(\\\"4630\\\");t.exports=n(\\\"9e1e\\\")?function(t,e,n){return r.f(t,e,i(1,n))}:function(t,e,n){return t[e]=n,t}},\\\"32ef\\\":function(t,e,n){var r=n(\\\"61ea\\\"),i=n(\\\"feb7\\\").polygon;t.exports=function(t,e,n,o,s){if(!t)throw new Error(\\\"center is required\\\");if(!e)throw new Error(\\\"radius is required\\\");n=n||64,s=s||t.properties||{};for(var a=[],u=0;u=31||\\\"undefined\\\"!==typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\\\\/(\\\\d+)/))}function o(t){var n=this.useColors;if(t[0]=(n?\\\"%c\\\":\\\"\\\")+this.namespace+(n?\\\" %c\\\":\\\" \\\")+t[0]+(n?\\\"%c \\\":\\\" \\\")+\\\"+\\\"+e.humanize(this.diff),n){var r=\\\"color: \\\"+this.color;t.splice(1,0,r,\\\"color: inherit\\\");var i=0,o=0;t[0].replace(/%[a-zA-Z%]/g,function(t){\\\"%%\\\"!==t&&(i++,\\\"%c\\\"===t&&(o=i))}),t.splice(o,0,r)}}function s(){return\\\"object\\\"===typeof console&&console.log&&Function.prototype.apply.call(console.log,console,arguments)}function a(t){try{null==t?e.storage.removeItem(\\\"debug\\\"):e.storage.debug=t}catch(n){}}function u(){var t;try{t=e.storage.debug}catch(n){}return!t&&\\\"undefined\\\"!==typeof r&&\\\"env\\\"in r&&(t=Object({NODE_ENV:\\\"production\\\",BASE_URL:\\\"/dist/\\\"}).DEBUG),t}function l(){try{return window.localStorage}catch(t){}}e=t.exports=n(\\\"96fe\\\"),e.log=s,e.formatArgs=o,e.save=a,e.load=u,e.useColors=i,e.storage=\\\"undefined\\\"!=typeof chrome&&\\\"undefined\\\"!=typeof chrome.storage?chrome.storage.local:l(),e.colors=[\\\"lightseagreen\\\",\\\"forestgreen\\\",\\\"goldenrod\\\",\\\"dodgerblue\\\",\\\"darkorchid\\\",\\\"crimson\\\"],e.formatters.j=function(t){try{return JSON.stringify(t)}catch(e){return\\\"[UnexpectedJSONParseError]: \\\"+e.message}},e.enable(u())}).call(this,n(\\\"f28c\\\"))},\\\"34fe\\\":function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"feb7\\\"),o=i.point,s=r.coordEach,a=r.featureEach,u=i.featureCollection;t.exports=function(t){var e=[];return\\\"FeatureCollection\\\"===t.type?a(t,function(t){s(t,function(n){e.push(o(n,t.properties))})}):s(t,function(n){e.push(o(n,t.properties))}),u(e)}},3863:function(t,e,n){\\\"use strict\\\";n.r(e);var r=function(t){var e=1/0,n=1/0,r=-1/0,i=-1/0;function o(t){null!=t&&s.hasOwnProperty(t.type)&&s[t.type](t)}var s={GeometryCollection:function(t){t.geometries.forEach(o)},Point:function(t){a(t.coordinates)},MultiPoint:function(t){t.coordinates.forEach(a)},LineString:function(t){u(t.arcs)},MultiLineString:function(t){t.arcs.forEach(u)},Polygon:function(t){t.arcs.forEach(u)},MultiPolygon:function(t){t.arcs.forEach(l)}};function a(t){var o=t[0],s=t[1];or&&(r=o),si&&(i=s)}function u(t){t.forEach(a)}function l(t){t.forEach(u)}for(var c in t)o(t[c]);return r>=e&&i>=n?[e,n,r,i]:void 0},i=function(t,e,n,r,i){3===arguments.length&&(r=Array,i=null);for(var o=new r(t=1<=t)throw new Error(\\\"full hashset\\\");u=o[a=a+1&s]}return o[a]=r,!0}function l(r){var a=e(r)&s,u=o[a],l=0;while(u!=i){if(n(u,r))return!0;if(++l>=t)break;u=o[a=a+1&s]}return!1}function c(){for(var t=[],e=0,n=o.length;e=t)throw new Error(\\\"full hashmap\\\");c=s[l=l+1&u]}return s[l]=r,a[l]=o,o}function h(r,o){var l=e(r)&u,c=s[l],h=0;while(c!=i){if(n(c,r))return a[l];if(++h>=t)throw new Error(\\\"full hashmap\\\");c=s[l=l+1&u]}return s[l]=r,a[l]=o,o}function f(r,o){var l=e(r)&u,c=s[l],h=0;while(c!=i){if(n(c,r))return a[l];if(++h>=t)break;c=s[l=l+1&u]}return o}function g(){for(var t=[],e=0,n=s.length;e>7^l[2]^l[3],2147483647&e},h=function(t){var e,n,r,a,u,l=t.coordinates,h=t.lines,f=t.rings,g=S(),d=new Int32Array(l.length),p=new Int32Array(l.length),v=new Int32Array(l.length),y=new Int8Array(l.length),m=0;for(e=0,n=l.length;e=0){var o=v[n];i===e&&o===r||i===r&&o===e||(++m,y[n]=1)}else p[n]=e,v[n]=r}}function S(){for(var t=o(1.4*l.length,M,_,Int32Array,-1,Int32Array),e=new Int32Array(l.length),n=0,r=l.length;n>1);e0&&n&&I(t,n,e),s=p(f(y(t))),a=s.coordinates,u=o(1.4*s.arcs.length,C,S);function l(t){t&&c.hasOwnProperty(t.type)&&c[t.type](t)}t=s.objects,s.bbox=n,s.arcs=s.arcs.map(function(t,e){return u.set(t,e),a.slice(t[0],t[1]+1)}),delete s.coordinates,a=null;var c={GeometryCollection:function(t){t.geometries.forEach(l)},LineString:function(t){t.arcs=h(t.arcs)},MultiLineString:function(t){t.arcs=t.arcs.map(h)},Polygon:function(t){t.arcs=t.arcs.map(h)},MultiPolygon:function(t){t.arcs=t.arcs.map(g)}};function h(t){var e=[];do{var n=u.get(t);e.push(t[0]0}},\\\"3b74\\\":function(t,e,n){var r=n(\\\"9a15\\\").geometry,i=n(\\\"716c\\\").geomReduce;t.exports=function(t){return i(t,function(t,e){return t+r(e)},0)}},\\\"3ba9\\\":function(t,e,n){var r=n(\\\"8678\\\"),i=n(\\\"feb7\\\").featureCollection;t.exports=function(t,e){for(var n=i([]),o=0;oe!=r[o][0]>e&&t<(r[o][1]-r[i][1])*(e-r[i][0])/(r[o][0]-r[i][0])+r[i][1]&&(s=!s);return s}t.exports&&(t.exports=e),e.lineStringsIntersect=function(t,e){for(var n=[],r=0;r<=t.coordinates.length-2;++r)for(var i=0;i<=e.coordinates.length-2;++i){var o={x:t.coordinates[r][1],y:t.coordinates[r][0]},s={x:t.coordinates[r+1][1],y:t.coordinates[r+1][0]},a={x:e.coordinates[i][1],y:e.coordinates[i][0]},u={x:e.coordinates[i+1][1],y:e.coordinates[i+1][0]},l=(u.x-a.x)*(o.y-a.y)-(u.y-a.y)*(o.x-a.x),c=(s.x-o.x)*(o.y-a.y)-(s.y-o.y)*(o.x-a.x),h=(u.y-a.y)*(s.x-o.x)-(u.x-a.x)*(s.y-o.y);if(0!=h){var f=l/h,g=c/h;0<=f&&f<=1&&0<=g&&g<=1&&n.push({type:\\\"Point\\\",coordinates:[o.x+f*(s.x-o.x),o.y+f*(s.y-o.y)]})}}return 0==n.length&&(n=!1),n},e.pointInBoundingBox=function(t,e){return!(t.coordinates[1]e[1][0]||t.coordinates[0]e[1][1])},e.pointInPolygon=function(t,i){for(var o=\\\"Polygon\\\"==i.type?[i.coordinates]:i.coordinates,s=!1,a=0;ar)return!1}return!0},e.area=function(t){for(var e=0,n=t.coordinates[0],r=n.length-1,i=0;i0)if(o=b[r-1],s=I[r-1],r--,s-o>1){for(h=t[s].lng()-t[o].lng(),f=t[s].lat()-t[o].lat(),Math.abs(h)>180&&(h=360-Math.abs(h)),h*=Math.cos(E*(t[s].lat()+t[o].lat())),g=h*h+f*f,C=o+1,a=o,l=-1;C180&&(d=360-Math.abs(d)),d*=Math.cos(E*(t[C].lat()+t[o].lat())),v=d*d+p*p,y=t[C].lng()-t[s].lng(),m=t[C].lat()-t[s].lat(),Math.abs(y)>180&&(y=360-Math.abs(y)),y*=Math.cos(E*(t[C].lat()+t[s].lat())),x=y*y+m*m,u=v>=g+x?x:x>=g+v?v:(d*f-p*h)*(d*f-p*h)/g,u>l&&(a=C,l=u);l is required\\\");if(\\\"boolean\\\"!==typeof e)throw new Error(\\\" must be a boolean\\\");if(\\\"boolean\\\"!==typeof n)throw new Error(\\\" must be a boolean\\\");!1!==n&&void 0!==n||(t=JSON.parse(JSON.stringify(t)));var r=[];switch(t.type){case\\\"GeometryCollection\\\":return a(t,function(t){l(t,e)}),t;case\\\"FeatureCollection\\\":return u(t,function(t){u(l(t,e),function(t){r.push(t)})}),s(r)}return l(t,e)}},\\\"404d\\\":function(t,e,n){\\\"use strict\\\";\\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*/\\nfunction r(t,e,n){return tr&&(i=n,n=r,r=i),tr?(t-r)/(t-e):(t-n)/(t-e)}function o(t,e,n,r){return tn||t[a][i-1]n){r=!1;break}if(r&&(t[o-1][0]n||t[o-1][i-1]n)&&(r=!1),r)for(s=0;sn||t[o-1][s]n){r=!1;break}return r}function d(t,e){var n,r,i,o,s;for(n=!0,r=t[0].length,i=t.length,s=0;s=e||t[s][r-1]>=e){n=!1;break}if(n&&(t[i-1][0]>=e||t[i-1][r-1]>=e)&&(n=!1),n)for(o=0;o=e||t[i-1][o]>e){n=!1;break}return n}function p(t,e,n){var r,i,o,s,a,u,l,c,d,p,v,y,m,x,E,w,b=[],I=t.length-1,N=t[0].length-1,C=[[\\\"rt\\\",\\\"rb\\\"],[\\\"br\\\",\\\"bl\\\"],[\\\"lb\\\",\\\"lt\\\"],[\\\"tl\\\",\\\"tr\\\"]],S=[0,-1,0,1],M=[-1,0,1,0],_=[\\\"bl\\\",\\\"lb\\\",\\\"lt\\\",\\\"tl\\\",\\\"tr\\\",\\\"rt\\\",\\\"rb\\\",\\\"br\\\"],L={bl:1,br:1,lb:2,lt:2,tl:3,tr:3,rt:0,rb:0};return g(t,n.minV,n.maxV)&&(n.linearRing?b.push([[0,0],[0,I],[N,I],[N,0],[0,0]]):b.push([[0,0],[0,I],[N,I],[N,0]])),e.forEach(function(t,g){t.forEach(function(t,P){for(r=null,o=0;o<8;o++)if(r=_[o],\\\"object\\\"===typeof t.edges[r]){i=[],s=t.edges[r],l=r,c=g,d=P,p=!1,v=[g+s.path[0][0],P+s.path[0][1]],i.push(v);while(!p){if(y=e[c][d],\\\"object\\\"!==typeof y.edges[l])break;if(s=y.edges[l],delete y.edges[l],E=s.path[1],E[0]+=c,E[1]+=d,i.push(E),l=s.move.enter,c+=s.move.x,d+=s.move.y,\\\"undefined\\\"===typeof e[c]||\\\"undefined\\\"===typeof e[c][d]){if(m=0,x=0,c===N)c--,m=0;else if(c<0)c++,m=2;else if(d===I)d--,m=3;else{if(!(d<0))throw new Error(\\\"Left the grid somewhere in the interior!\\\");d++,m=1}if(c===g&&d===P&&m===L[r]){p=!0,l=r;break}while(1){if(w=!1,x>4)throw new Error(\\\"Direction change counter overflow! This should never happen!\\\");if(\\\"undefined\\\"!==typeof e[c]&&\\\"undefined\\\"!==typeof e[c][d])for(y=e[c][d],a=0;a4)throw new Error(\\\"Direction change counter overflow! This should never happen!\\\");if(\\\"undefined\\\"!==typeof e[l]&&\\\"undefined\\\"!==typeof e[l][c]&&(s=e[l][c],E=N[y],\\\"object\\\"===typeof s.edges[E])){o=s.edges[E],a.push(h(l,c,y,o.path)),u=E,x=!0;break}if(x)break;if(a.push(f(l,c,y)),l+=C[y],c+=S[y],\\\"undefined\\\"!==typeof e[l]&&\\\"undefined\\\"!==typeof e[l][c]||(0===y&&c<0||1===y&&l<0||2===y&&c===b||3===y&&l===I)&&(l-=C[y],c-=S[y],y=(y+1)%4,m++),l===d&&c===_&&y===M[r]){g=!0,u=r;break}}}}!n.linearRing||a[a.length-1][0]===p[0]&&a[a.length-1][1]===p[1]||a.push(p),w.push(a)}})}),w}function y(t,e,n,r,i){var o=r,s=i,a=0,u=0;if(this.x=e,this.y=n,this.lowerBound=null,this.upperBound=null,this.childA=null,this.childB=null,this.childC=null,this.childD=null,1===r&&1===i)this.lowerBound=Math.min(t[n][e],t[n][e+1],t[n+1][e+1],t[n+1][e]),this.upperBound=Math.max(t[n][e],t[n][e+1],t[n+1][e+1],t[n+1][e]);else{if(r>1){while(0!==o)o>>=1,a++;r===1<1){while(0!==s)s>>=1,u++;i===1<0&&(this.childB=new y(t,e+o,n,r-o,s),this.lowerBound=Math.min(this.lowerBound,this.childB.lowerBound),this.upperBound=Math.max(this.upperBound,this.childB.upperBound),i-s>0&&(this.childC=new y(t,e+o,n+s,r-o,i-s),this.lowerBound=Math.min(this.lowerBound,this.childC.lowerBound),this.upperBound=Math.max(this.upperBound,this.childC.upperBound))),i-s>0&&(this.childD=new y(t,e,n+s,o,i-s),this.lowerBound=Math.min(this.lowerBound,this.childD.lowerBound),this.upperBound=Math.max(this.upperBound,this.childD.upperBound))}}function m(t){var e,n;if(!t)throw new Error(\\\"data is required\\\");if(!Array.isArray(t)||!Array.isArray(t[0]))throw new Error(\\\"data must be scalar field, i.e. array of arrays\\\");if(t.length<2)throw new Error(\\\"data must contain at least two rows\\\");if(n=t[0].length,n<2)throw new Error(\\\"data must contain at least two columns\\\");for(e=1;e=p?8:0,c|=f>=p?4:0,c|=g>=p?2:0,c|=d>=p?1:0,c=+c,l={cval:c,polygons:[],edges:{},x0:d,x1:g,x2:f,x3:h},c){case 0:r.polygons&&l.polygons.push([[0,0],[0,1],[1,1],[1,0]]);break;case 15:break;case 14:i=r.interpolate(d,h,p),a=r.interpolate(d,g,p),r.polygons_full&&(l.edges.left={path:[[0,i],[a,0]],move:{x:0,y:-1,enter:\\\"top\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,i],[a,0]]);break;case 13:a=r.interpolate(d,g,p),o=r.interpolate(g,f,p),r.polygons_full&&(l.edges.bottom={path:[[a,0],[1,o]],move:{x:1,y:0,enter:\\\"left\\\"}}),r.polygons&&l.polygons.push([[a,0],[1,o],[1,0]]);break;case 11:o=r.interpolate(g,f,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.right={path:[[1,o],[s,1]],move:{x:0,y:1,enter:\\\"bottom\\\"}}),r.polygons&&l.polygons.push([[1,o],[s,1],[1,1]]);break;case 7:i=r.interpolate(d,h,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.top={path:[[s,1],[0,i]],move:{x:-1,y:0,enter:\\\"right\\\"}}),r.polygons&&l.polygons.push([[s,1],[0,i],[0,1]]);break;case 1:i=r.interpolate(d,h,p),a=r.interpolate(d,g,p),r.polygons_full&&(l.edges.bottom={path:[[a,0],[0,i]],move:{x:-1,y:0,enter:\\\"right\\\"}}),r.polygons&&l.polygons.push([[a,0],[0,i],[0,1],[1,1],[1,0]]);break;case 2:a=r.interpolate(d,g,p),o=r.interpolate(g,f,p),r.polygons_full&&(l.edges.right={path:[[1,o],[a,0]],move:{x:0,y:-1,enter:\\\"top\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,1],[1,1],[1,o],[a,0]]);break;case 4:o=r.interpolate(g,f,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.top={path:[[s,1],[1,o]],move:{x:1,y:0,enter:\\\"left\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,1],[s,1],[1,o],[1,0]]);break;case 8:i=r.interpolate(d,h,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.left={path:[[0,i],[s,1]],move:{x:0,y:1,enter:\\\"bottom\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,i],[s,1],[1,1],[1,0]]);break;case 12:i=r.interpolate(d,h,p),o=r.interpolate(g,f,p),r.polygons_full&&(l.edges.left={path:[[0,i],[1,o]],move:{x:1,y:0,enter:\\\"left\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,i],[1,o],[1,0]]);break;case 9:a=r.interpolate(d,g,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.bottom={path:[[a,0],[s,1]],move:{x:0,y:1,enter:\\\"bottom\\\"}}),r.polygons&&l.polygons.push([[a,0],[s,1],[1,1],[1,0]]);break;case 3:i=r.interpolate(d,h,p),o=r.interpolate(g,f,p),r.polygons_full&&(l.edges.right={path:[[1,o],[0,i]],move:{x:-1,y:0,enter:\\\"right\\\"}}),r.polygons&&l.polygons.push([[0,i],[0,1],[1,1],[1,o]]);break;case 6:a=r.interpolate(d,g,p),s=r.interpolate(h,f,p),r.polygons_full&&(l.edges.top={path:[[s,1],[a,0]],move:{x:0,y:-1,enter:\\\"top\\\"}}),r.polygons&&l.polygons.push([[0,0],[0,1],[s,1],[a,0]]);break;case 10:i=r.interpolate(d,h,p),o=r.interpolate(g,f,p),a=r.interpolate(d,g,p),s=r.interpolate(h,f,p),u=(d+g+f+h)/4,r.polygons_full&&(ue||this.upperBound=e)&&r.push({x:this.x,y:this.y}),r)},y.prototype.cellsBelowThreshold=function(t,e){var n=[];return e=\\\"undefined\\\"===typeof e||e,this.lowerBound>t?n:(this.childA||this.childB||this.childC||this.childD?(this.childA&&(n=n.concat(this.childA.cellsBelowThreshold(t,e))),this.childB&&(n=n.concat(this.childB.cellsBelowThreshold(t,e))),this.childD&&(n=n.concat(this.childD.cellsBelowThreshold(t,e))),this.childC&&(n=n.concat(this.childC.cellsBelowThreshold(t,e)))):(e||this.upperBound>=t)&&n.push({x:this.x,y:this.y}),n)};var w={square:function(t,e,n,r,i,o){o.polygons&&t.polygons.push([[0,0],[0,1],[1,1],[1,0]])},triangle_bl:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(e,i,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,a],[s,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,a],[s,0],[0,0]])},triangle_br:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[1,a]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[s,0],[1,a],[1,0]])},triangle_tr:function(t,e,n,r,i,o){var s=o.interpolate(n,r,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV);o.polygons_full&&(t.edges.rt={path:[[1,s],[a,1]],move:{x:0,y:1,enter:\\\"br\\\"}}),o.polygons&&t.polygons.push([[1,s],[a,1],[1,1]])},triangle_tl:function(t,e,n,r,i,o){var s=o.interpolate(i,r,o.minV,o.maxV),a=o.interpolate(e,i,o.minV,o.maxV);o.polygons_full&&(t.edges.tl={path:[[s,1],[0,a]],move:{x:-1,y:0,enter:\\\"rt\\\"}}),o.polygons&&t.polygons.push([[0,a],[0,1],[s,1]])},tetragon_t:function(t,e,n,r,i,o){var s=o.interpolate(n,r,o.minV,o.maxV),a=o.interpolate(e,i,o.minV,o.maxV);o.polygons_full&&(t.edges.rt={path:[[1,s],[0,a]],move:{x:-1,y:0,enter:\\\"rt\\\"}}),o.polygons&&t.polygons.push([[0,a],[0,1],[1,1],[1,s]])},tetragon_r:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[a,1]],move:{x:0,y:1,enter:\\\"br\\\"}}),o.polygons&&t.polygons.push([[s,0],[a,1],[1,1],[1,0]])},tetragon_b:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[1,a]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[1,a],[1,0]])},tetragon_l:function(t,e,n,r,i,o){var s=o.interpolate(i,r,o.minV,o.maxV),a=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.tl={path:[[s,1],[a,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,1],[s,1],[a,0]])},tetragon_bl:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate_a(e,i,o.minV,o.maxV),l=o.interpolate_b(e,i,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[0,u]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,l],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,u],[0,l],[a,0]])},tetragon_br:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate_a(n,r,o.minV,o.maxV),l=o.interpolate_b(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[1,l]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,u],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[1,l],[1,u],[a,0]])},tetragon_tr:function(t,e,n,r,i,o){var s=o.interpolate_a(i,r,o.minV,o.maxV),a=o.interpolate_b(i,r,o.minV,o.maxV),u=o.interpolate_b(n,r,o.minV,o.maxV),l=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.rb={path:[[1,l],[s,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[a,1],[1,u]],move:{x:1,y:0,enter:\\\"lt\\\"}}),o.polygons&&t.polygons.push([[1,l],[s,1],[a,1],[1,u]])},tetragon_tl:function(t,e,n,r,i,o){var s=o.interpolate_a(i,r,o.minV,o.maxV),a=o.interpolate_b(i,r,o.minV,o.maxV),u=o.interpolate_b(e,i,o.minV,o.maxV),l=o.interpolate_a(e,i,o.minV,o.maxV);o.polygons_full&&(t.edges.tr={path:[[a,1],[0,l]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,u],[s,1]],move:{x:0,y:1,enter:\\\"bl\\\"}}),o.polygons&&t.polygons.push([[a,1],[0,l],[0,u],[s,1]])},tetragon_lr:function(t,e,n,r,i,o){var s=o.interpolate_a(e,i,o.minV,o.maxV),a=o.interpolate_b(e,i,o.minV,o.maxV),u=o.interpolate_b(n,r,o.minV,o.maxV),l=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.lt={path:[[0,a],[1,u]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,l],[0,s]],move:{x:-1,y:0,enter:\\\"rb\\\"}}),o.polygons&&t.polygons.push([[0,s],[0,a],[1,u],[1,l]])},tetragon_tb:function(t,e,n,r,i,o){var s=o.interpolate_a(i,r,o.minV,o.maxV),a=o.interpolate_b(i,r,o.minV,o.maxV),u=o.interpolate_b(e,n,o.minV,o.maxV),l=o.interpolate_a(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.tr={path:[[a,1],[u,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}},t.edges.bl={path:[[l,0],[s,1]],move:{x:0,y:1,enter:\\\"bl\\\"}}),o.polygons&&t.polygons.push([[l,0],[s,1],[a,1],[u,0]])},pentagon_tr:function(t,e,n,r,i,o){var s=o.interpolate(i,r,o.minV,o.maxV),a=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.tl={path:[[s,1],[1,a]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,1],[s,1],[1,a],[1,0]])},pentagon_tl:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[a,1]],move:{x:0,y:1,enter:\\\"br\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[a,1],[1,1],[1,0]])},pentagon_br:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.rt={path:[[1,a],[s,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,1],[1,1],[1,a],[s,0]])},pentagon_bl:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[a,0],[0,s]],move:{x:-1,y:0,enter:\\\"rt\\\"}}),o.polygons&&t.polygons.push([[0,s],[0,1],[1,1],[1,0],[a,0]])},pentagon_tr_rl:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV),u=o.interpolate_b(n,r,o.minV,o.maxV),l=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.tl={path:[[a,1],[1,u]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,l],[0,s]],move:{x:-1,y:0,enter:\\\"rt\\\"}}),o.polygons&&t.polygons.push([[0,s],[0,1],[a,1],[1,u],[1,l]])},pentagon_rb_bt:function(t,e,n,r,i,o){var s=o.interpolate(n,r,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate_a(e,n,o.minV,o.maxV),l=o.interpolate(i,r,o.minV,o.maxV);o.polygons_full&&(t.edges.rt={path:[[1,s],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}},t.edges.bl={path:[[u,0],[l,1]],move:{x:0,y:1,enter:\\\"br\\\"}}),o.polygons&&t.polygons.push([[l,1],[1,1],[1,s],[a,0],[u,0]])},pentagon_bl_lr:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate_a(e,i,o.minV,o.maxV),u=o.interpolate_b(e,i,o.minV,o.maxV),l=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[0,a]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,u],[1,l]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,a],[0,u],[1,l],[1,0]])},pentagon_lt_tb:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate_a(i,r,o.minV,o.maxV),u=o.interpolate_b(i,r,o.minV,o.maxV),l=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[a,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[u,1],[l,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[a,1],[u,1],[l,0]])},pentagon_bl_tb:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV),u=o.interpolate_b(e,n,o.minV,o.maxV),l=o.interpolate_a(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[l,0],[0,s]],move:{x:-1,y:0,enter:\\\"rt\\\"}},t.edges.tl={path:[[a,1],[u,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[0,s],[0,1],[a,1],[u,0],[l,0]])},pentagon_lt_rl:function(t,e,n,r,i,o){var s=o.interpolate_a(e,i,o.minV,o.maxV),a=o.interpolate_b(e,i,o.minV,o.maxV),u=o.interpolate(i,r,o.minV,o.maxV),l=o.interpolate(n,i,o.minV,o.maxV);o.polygons_full&&(t.edges.lt={path:[[0,a],[u,1]],move:{x:0,y:1,enter:\\\"br\\\"}},t.edges.rt={path:[[1,l],[0,s]],move:{x:-1,y:0,enter:\\\"rb\\\"}}),o.polygons&&t.polygons.push([[0,s],[0,a],[u,1],[1,1],[1,l]])},pentagon_tr_bt:function(t,e,n,r,i,o){var s=o.interpolate_a(i,r,o.minV,o.maxV),a=o.interpolate_b(i,r,o.minV,o.maxV),u=o.interpolate(n,r,o.minV,o.maxV),l=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[l,0],[s,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[a,1],[1,u]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[s,1],[a,1],[1,u],[1,0],[l,0]])},pentagon_rb_lr:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate_b(n,r,o.minV,o.maxV),u=o.interpolate_a(n,r,o.minV,o.maxV),l=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[1,a]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,u],[l,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[1,a],[1,u],[l,0]])},hexagon_lt_tr:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate_a(i,r,o.minV,o.maxV),u=o.interpolate_b(i,r,o.minV,o.maxV),l=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[a,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[u,1],[1,l]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[a,1],[u,1],[1,l],[1,0]])},hexagon_bl_lt:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate_a(e,i,o.minV,o.maxV),u=o.interpolate_b(e,i,o.minV,o.maxV),l=o.interpolate(i,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[0,a]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,u],[l,1]],move:{x:0,y:1,enter:\\\"br\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,a],[0,u],[l,1],[1,1],[1,0]])},hexagon_bl_rb:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate(e,i,o.minV,o.maxV),l=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[0,u]],move:{x:-1,y:0,enter:\\\"rt\\\"}},t.edges.rt={path:[[1,l],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,u],[0,1],[1,1],[1,l],[a,0]])},hexagon_tr_rb:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV),u=o.interpolate_b(n,r,o.minV,o.maxV),l=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.tl={path:[[a,1],[1,u]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,l],[s,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,1],[a,1],[1,u],[1,l],[s,0]])},hexagon_lt_rb:function(t,e,n,r,i,o){var s=o.interpolate(e,i,o.minV,o.maxV),a=o.interpolate(i,r,o.minV,o.maxV),u=o.interpolate(n,r,o.minV,o.maxV),l=o.interpolate(e,n,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,s],[a,1]],move:{x:0,y:1,enter:\\\"br\\\"}},t.edges.rt={path:[[1,u],[l,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,s],[a,1],[1,1],[1,u],[l,0]])},hexagon_bl_tr:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(e,i,o.minV,o.maxV),u=o.interpolate(i,r,o.minV,o.maxV),l=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[0,a]],move:{x:-1,y:0,enter:\\\"rt\\\"}},t.edges.tl={path:[[u,1],[1,l]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,a],[0,1],[u,1],[1,l],[1,0]])},heptagon_tr:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate_a(e,i,o.minV,o.maxV),l=o.interpolate_b(e,i,o.minV,o.maxV),c=o.interpolate(i,r,o.minV,o.maxV),h=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[0,u]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,l],[c,1]],move:{x:0,y:1,enter:\\\"br\\\"}},t.edges.rt={path:[[1,h],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,u],[0,l],[c,1],[1,1],[1,h],[a,0]])},heptagon_bl:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate(e,i,o.minV,o.maxV),u=o.interpolate_a(i,r,o.minV,o.maxV),l=o.interpolate_b(i,r,o.minV,o.maxV),c=o.interpolate_b(n,r,o.minV,o.maxV),h=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.lb={path:[[0,a],[u,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[l,1],[1,c]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,h],[s,0]],move:{x:0,y:-1,enter:\\\"tl\\\"}}),o.polygons&&t.polygons.push([[0,0],[0,a],[u,1],[l,1],[1,c],[1,h],[s,0]])},heptagon_tl:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate(e,i,o.minV,o.maxV),l=o.interpolate(i,r,o.minV,o.maxV),c=o.interpolate_b(n,r,o.minV,o.maxV),h=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[0,u]],move:{x:-1,y:0,enter:\\\"rt\\\"}},t.edges.tl={path:[[l,1],[1,c]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,h],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,u],[0,1],[l,1],[1,c],[1,h],[a,0]])},heptagon_br:function(t,e,n,r,i,o){var s=o.interpolate(e,n,o.minV,o.maxV),a=o.interpolate_a(e,i,o.minV,o.maxV),u=o.interpolate_b(e,i,o.minV,o.maxV),l=o.interpolate_a(i,r,o.minV,o.maxV),c=o.interpolate_b(i,r,o.minV,o.maxV),h=o.interpolate(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.br={path:[[s,0],[0,a]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,u],[l,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[c,1],[1,h]],move:{x:1,y:0,enter:\\\"lb\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,a],[0,u],[l,1],[c,1],[1,h],[1,0]])},octagon:function(t,e,n,r,i,o){var s=o.interpolate_a(e,n,o.minV,o.maxV),a=o.interpolate_b(e,n,o.minV,o.maxV),u=o.interpolate_a(e,i,o.minV,o.maxV),l=o.interpolate_b(e,i,o.minV,o.maxV),c=o.interpolate_a(i,r,o.minV,o.maxV),h=o.interpolate_b(i,r,o.minV,o.maxV),f=o.interpolate_b(n,r,o.minV,o.maxV),g=o.interpolate_a(n,r,o.minV,o.maxV);o.polygons_full&&(t.edges.bl={path:[[s,0],[0,u]],move:{x:-1,y:0,enter:\\\"rb\\\"}},t.edges.lt={path:[[0,l],[c,1]],move:{x:0,y:1,enter:\\\"bl\\\"}},t.edges.tr={path:[[h,1],[1,f]],move:{x:1,y:0,enter:\\\"lt\\\"}},t.edges.rb={path:[[1,g],[a,0]],move:{x:0,y:-1,enter:\\\"tr\\\"}}),o.polygons&&t.polygons.push([[s,0],[0,u],[0,l],[c,1],[h,1],[1,f],[1,g],[a,0]])}};function b(t,e,n,r){var i,o,s,a=!1,l=null,h=null,f=null,g=null,d=!1,v=[],y=[],x=[];if(!t)throw new Error(\\\"data is required\\\");if(void 0===e||null===e)throw new Error(\\\"lowerBound is required\\\");if(void 0===n||null===n)throw new Error(\\\"bandWidth is required\\\");if(r&&\\\"object\\\"!==typeof r)throw new Error(\\\"options must be an object\\\");if(s=u(r),t instanceof m)l=t,h=t.root,f=t.data,s.noQuadTree||(a=!0);else{if(!Array.isArray(t)||!Array.isArray(t[0]))throw new Error(\\\"input is neither array of arrays nor object retrieved from 'QuadTree()'\\\");f=t}if(Array.isArray(e)){for(d=!0,s.noQuadTree||(a=!0),i=0;io?2:sf?128:64,s|=uf?32:16,s|=lf?8:4,s|=cf?2:1,s=+s,o=0,i={cval:s,polygons:[],edges:{},x0:c,x1:l,x2:u,x3:a,x:e,y:n},s){case 85:w.square(i,c,l,u,a,r);case 0:case 170:break;case 169:w.triangle_bl(i,c,l,u,a,r);break;case 166:w.triangle_br(i,c,l,u,a,r);break;case 154:w.triangle_tr(i,c,l,u,a,r);break;case 106:w.triangle_tl(i,c,l,u,a,r);break;case 1:w.triangle_bl(i,c,l,u,a,r);break;case 4:w.triangle_br(i,c,l,u,a,r);break;case 16:w.triangle_tr(i,c,l,u,a,r);break;case 64:w.triangle_tl(i,c,l,u,a,r);break;case 168:w.tetragon_bl(i,c,l,u,a,r);break;case 162:w.tetragon_br(i,c,l,u,a,r);break;case 138:w.tetragon_tr(i,c,l,u,a,r);break;case 42:w.tetragon_tl(i,c,l,u,a,r);break;case 2:w.tetragon_bl(i,c,l,u,a,r);break;case 8:w.tetragon_br(i,c,l,u,a,r);break;case 32:w.tetragon_tr(i,c,l,u,a,r);break;case 128:w.tetragon_tl(i,c,l,u,a,r);break;case 5:w.tetragon_b(i,c,l,u,a,r);break;case 20:w.tetragon_r(i,c,l,u,a,r);break;case 80:w.tetragon_t(i,c,l,u,a,r);break;case 65:w.tetragon_l(i,c,l,u,a,r);break;case 165:w.tetragon_b(i,c,l,u,a,r);break;case 150:w.tetragon_r(i,c,l,u,a,r);break;case 90:w.tetragon_t(i,c,l,u,a,r);break;case 105:w.tetragon_l(i,c,l,u,a,r);break;case 160:w.tetragon_lr(i,c,l,u,a,r);break;case 130:w.tetragon_tb(i,c,l,u,a,r);break;case 10:w.tetragon_lr(i,c,l,u,a,r);break;case 40:w.tetragon_tb(i,c,l,u,a,r);break;case 101:w.pentagon_tr(i,c,l,u,a,r);break;case 149:w.pentagon_tl(i,c,l,u,a,r);break;case 86:w.pentagon_bl(i,c,l,u,a,r);break;case 89:w.pentagon_br(i,c,l,u,a,r);break;case 69:w.pentagon_tr(i,c,l,u,a,r);break;case 21:w.pentagon_tl(i,c,l,u,a,r);break;case 84:w.pentagon_bl(i,c,l,u,a,r);break;case 81:w.pentagon_br(i,c,l,u,a,r);break;case 96:w.pentagon_tr_rl(i,c,l,u,a,r);break;case 24:w.pentagon_rb_bt(i,c,l,u,a,r);break;case 6:w.pentagon_bl_lr(i,c,l,u,a,r);break;case 129:w.pentagon_lt_tb(i,c,l,u,a,r);break;case 74:w.pentagon_tr_rl(i,c,l,u,a,r);break;case 146:w.pentagon_rb_bt(i,c,l,u,a,r);break;case 164:w.pentagon_bl_lr(i,c,l,u,a,r);break;case 41:w.pentagon_lt_tb(i,c,l,u,a,r);break;case 66:w.pentagon_bl_tb(i,c,l,u,a,r);break;case 144:w.pentagon_lt_rl(i,c,l,u,a,r);break;case 36:w.pentagon_tr_bt(i,c,l,u,a,r);break;case 9:w.pentagon_rb_lr(i,c,l,u,a,r);break;case 104:w.pentagon_bl_tb(i,c,l,u,a,r);break;case 26:w.pentagon_lt_rl(i,c,l,u,a,r);break;case 134:w.pentagon_tr_bt(i,c,l,u,a,r);break;case 161:w.pentagon_rb_lr(i,c,l,u,a,r);break;case 37:w.hexagon_lt_tr(i,c,l,u,a,r);break;case 148:w.hexagon_bl_lt(i,c,l,u,a,r);break;case 82:w.hexagon_bl_rb(i,c,l,u,a,r);break;case 73:w.hexagon_tr_rb(i,c,l,u,a,r);break;case 133:w.hexagon_lt_tr(i,c,l,u,a,r);break;case 22:w.hexagon_bl_lt(i,c,l,u,a,r);break;case 88:w.hexagon_bl_rb(i,c,l,u,a,r);break;case 97:w.hexagon_tr_rb(i,c,l,u,a,r);break;case 145:w.hexagon_lt_rb(i,c,l,u,a,r);break;case 25:w.hexagon_lt_rb(i,c,l,u,a,r);break;case 70:w.hexagon_bl_tr(i,c,l,u,a,r);break;case 100:w.hexagon_bl_tr(i,c,l,u,a,r);break;case 17:o=I(c,l,u,a,h,f),0===o?(w.triangle_bl(i,c,l,u,a,r),w.triangle_tr(i,c,l,u,a,r)):w.hexagon_lt_rb(i,c,l,u,a,r);break;case 68:o=I(c,l,u,a,h,f),0===o?(w.triangle_tl(i,c,l,u,a,r),w.triangle_br(i,c,l,u,a,r)):w.hexagon_bl_tr(i,c,l,u,a,r);break;case 153:o=I(c,l,u,a,h,f),2===o?(w.triangle_bl(i,c,l,u,a,r),w.triangle_tr(i,c,l,u,a,r)):w.hexagon_lt_rb(i,c,l,u,a,r);break;case 102:o=I(c,l,u,a,h,f),2===o?(w.triangle_tl(i,c,l,u,a,r),w.triangle_br(i,c,l,u,a,r)):w.hexagon_bl_tr(i,c,l,u,a,r);break;case 152:o=I(c,l,u,a,h,f),2===o?(w.triangle_tr(i,c,l,u,a,r),w.tetragon_bl(i,c,l,u,a,r)):w.heptagon_tr(i,c,l,u,a,r);break;case 137:o=I(c,l,u,a,h,f),2===o?(w.triangle_bl(i,c,l,u,a,r),w.tetragon_tr(i,c,l,u,a,r)):w.heptagon_bl(i,c,l,u,a,r);break;case 98:o=I(c,l,u,a,h,f),2===o?(w.triangle_tl(i,c,l,u,a,r),w.tetragon_br(i,c,l,u,a,r)):w.heptagon_tl(i,c,l,u,a,r);break;case 38:o=I(c,l,u,a,h,f),2===o?(w.triangle_br(i,c,l,u,a,r),w.tetragon_tl(i,c,l,u,a,r)):w.heptagon_br(i,c,l,u,a,r);break;case 18:o=I(c,l,u,a,h,f),0===o?(w.triangle_tr(i,c,l,u,a,r),w.tetragon_bl(i,c,l,u,a,r)):w.heptagon_tr(i,c,l,u,a,r);break;case 33:o=I(c,l,u,a,h,f),0===o?(w.triangle_bl(i,c,l,u,a,r),w.tetragon_tr(i,c,l,u,a,r)):w.heptagon_bl(i,c,l,u,a,r);break;case 72:o=I(c,l,u,a,h,f),0===o?(w.triangle_tl(i,c,l,u,a,r),w.tetragon_br(i,c,l,u,a,r)):w.heptagon_tl(i,c,l,u,a,r);break;case 132:o=I(c,l,u,a,h,f),0===o?(w.triangle_br(i,c,l,u,a,r),w.tetragon_tl(i,c,l,u,a,r)):w.heptagon_br(i,c,l,u,a,r);break;case 136:o=I(c,l,u,a,h,f),0===o?(w.tetragon_tl(i,c,l,u,a,r),w.tetragon_br(i,c,l,u,a,r)):1===o?w.octagon(i,c,l,u,a,r):(w.tetragon_bl(i,c,l,u,a,r),w.tetragon_tr(i,c,l,u,a,r));break;case 34:o=I(c,l,u,a,h,f),0===o?(w.tetragon_bl(i,c,l,u,a,r),w.tetragon_tr(i,c,l,u,a,r)):1===o?w.octagon(i,c,l,u,a,r):(w.tetragon_tl(i,c,l,u,a,r),w.tetragon_br(i,c,l,u,a,r));break}return i}}},\\\"409f\\\":function(t,e,n){var r=n(\\\"716c\\\").coordEach;t.exports=function(t){var e=[1/0,1/0,-1/0,-1/0];return r(t,function(t){e[0]>t[0]&&(e[0]=t[0]),e[1]>t[1]&&(e[1]=t[1]),e[2]180?-360:l[0]-c[0]>180?360:0;var h=l.rhumbDistanceTo(c),f=s(a(h,\\\"meters\\\"),n);return f}},4485:function(t,e,n){\\\"use strict\\\";var r=function(){function t(t,e){for(var n=0;nt.edges[e].from.coordinates[1]&&(e=r),e},0),n=(0===e?this.length:e)-1,r=(e+1)%this.length,i=s(this.edges[n].from.coordinates,this.edges[e].from.coordinates,this.edges[r].from.coordinates);return 0===i?this.edges[n].from.coordinates[0]>this.edges[r].from.coordinates[0]:i>0}},{key:\\\"toMultiPoint\\\",value:function(){return h(this.edges.map(function(t){return t.from.coordinates}))}},{key:\\\"toPolygon\\\",value:function(){if(this.polygon)return this.polygon;var t=this.edges.map(function(t){return t.from.coordinates});return t.push(this.edges[0].from.coordinates),this.polygon=f([t])}},{key:\\\"getEnvelope\\\",value:function(){return this.envelope?this.envelope:this.envelope=d(this.toPolygon())}},{key:\\\"inside\\\",value:function(t){return p(t,this.toPolygon())}},{key:\\\"length\\\",get:function(){return this.edges.length}}],[{key:\\\"findEdgeRingContaining\\\",value:function(t,e){var n=t.getEnvelope(),r=void 0,i=void 0;return e.forEach(function(e){var o=e.getEnvelope();if(i&&(r=i.getEnvelope()),!a(o,n)&&u(o,n)){var s=t.map(function(t){return t.from.coordinates}).find(function(t){return!e.some(function(e){return l(t,e.from.coordinates)})});s&&e.inside(g(s))&&(i&&!u(r,o)||(i=e))}}),i}}]),t}();t.exports=v},\\\"456d\\\":function(t,e,n){var r=n(\\\"4bf8\\\"),i=n(\\\"0d58\\\");n(\\\"5eda\\\")(\\\"keys\\\",function(){return function(t){return i(r(t))}})},4588:function(t,e){var n=Math.ceil,r=Math.floor;t.exports=function(t){return isNaN(t=+t)?0:(t>0?r:n)(t)}},4630:function(t,e){t.exports=function(t,e){return{enumerable:!(1&t),configurable:!(2&t),writable:!(4&t),value:e}}},\\\"467f\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"2d83\\\");t.exports=function(t,e,n){var i=n.config.validateStatus;!i||i(n.status)?t(n):e(r(\\\"Request failed with status code \\\"+n.status,n.config,null,n.request,n))}},\\\"48f0\\\":function(t,e,n){var r=n(\\\"409f\\\"),i=n(\\\"feb7\\\").point;t.exports=function(t,e){var n=r(t),o=(n[0]+n[2])/2,s=(n[1]+n[3])/2;return i([o,s],e)}},\\\"49e7\\\":function(t,e,n){var r=n(\\\"1bf7\\\"),i=n(\\\"feb7\\\"),o=n(\\\"8f76\\\"),s=n(\\\"595b\\\"),a=n(\\\"716c\\\").featureEach,u=i.feature,l=i.featureCollection;function c(t){var e=[],n={};return a(t,function(t){if(t.geometry){var r=t.geometry.coordinates.join(\\\"-\\\");n.hasOwnProperty(r)||(e.push(t),n[r]=!0)}}),l(e)}t.exports=function(t,e,n){if(!t)throw new Error(\\\"points is required\\\");if(void 0===e||null===e)throw new Error(\\\"maxEdge is required\\\");if(\\\"number\\\"!==typeof e)throw new Error(\\\"invalid maxEdge\\\");var i=c(t),a=r(i);if(a.features=a.features.filter(function(t){var r=t.geometry.coordinates[0][0],i=t.geometry.coordinates[0][1],s=t.geometry.coordinates[0][2],a=o(r,i,n),u=o(i,s,n),l=o(r,s,n);return a<=e&&u<=e&&l<=e}),a.features.length<1)throw new Error(\\\"too few polygons found to compute concave hull\\\");var l=s(a.features);return 1===l.coordinates.length&&(l.coordinates=l.coordinates[0],l.type=\\\"Polygon\\\"),u(l)}},\\\"4a7b\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\");t.exports=function(t,e){e=e||{};var n={};return r.forEach([\\\"url\\\",\\\"method\\\",\\\"params\\\",\\\"data\\\"],function(t){\\\"undefined\\\"!==typeof e[t]&&(n[t]=e[t])}),r.forEach([\\\"headers\\\",\\\"auth\\\",\\\"proxy\\\"],function(i){r.isObject(e[i])?n[i]=r.deepMerge(t[i],e[i]):\\\"undefined\\\"!==typeof e[i]?n[i]=e[i]:r.isObject(t[i])?n[i]=r.deepMerge(t[i]):\\\"undefined\\\"!==typeof t[i]&&(n[i]=t[i])}),r.forEach([\\\"baseURL\\\",\\\"transformRequest\\\",\\\"transformResponse\\\",\\\"paramsSerializer\\\",\\\"timeout\\\",\\\"withCredentials\\\",\\\"adapter\\\",\\\"responseType\\\",\\\"xsrfCookieName\\\",\\\"xsrfHeaderName\\\",\\\"onUploadProgress\\\",\\\"onDownloadProgress\\\",\\\"maxContentLength\\\",\\\"validateStatus\\\",\\\"maxRedirects\\\",\\\"httpAgent\\\",\\\"httpsAgent\\\",\\\"cancelToken\\\",\\\"socketPath\\\"],function(r){\\\"undefined\\\"!==typeof e[r]?n[r]=e[r]:\\\"undefined\\\"!==typeof t[r]&&(n[r]=t[r])}),n}},\\\"4aa5\\\":function(t,e,n){var r=n(\\\"409f\\\"),i=n(\\\"8f76\\\"),o=n(\\\"8dde\\\"),s=n(\\\"6a00\\\");t.exports=function(t,e,n,a,u){if(!e)throw new Error(\\\"valueField is required\\\");if(void 0===n||null===n)throw new Error(\\\"weight is required\\\");if(void 0===a||null===a)throw new Error(\\\"cellWidth is required\\\");var l=t.features.filter(function(t){return t.properties&&t.properties.hasOwnProperty(e)});if(0===l.length)throw new Error(\\\"Specified Data Field is Missing\\\");for(var c=s(r(t),a,u),h=c.features.length,f=0;fn&&t.splice(n,t.length);for(var r=0;r is required\\\");if(\\\"number\\\"!==typeof e)throw new Error(\\\" must be a number\\\");if(\\\"number\\\"!==typeof n)throw new Error(\\\" must be a number\\\");!1!==o&&void 0!==o||(t=JSON.parse(JSON.stringify(t)));var s=Math.pow(10,e);return r(t,function(t){i(t,s,n)}),t}},5147:function(t,e,n){var r=n(\\\"2b4c\\\")(\\\"match\\\");t.exports=function(t){var e=/./;try{\\\"/./\\\"[t](e)}catch(n){try{return e[r]=!1,!\\\"/./\\\"[t](e)}catch(i){}}return!0}},5160:function(t,e,n){var r=n(\\\"feb7\\\").polygon;t.exports=function(t){var e=[t[0],t[1]],n=[t[0],t[3]],i=[t[2],t[3]],o=[t[2],t[1]];return r([[e,o,i,n,e]])}},5174:function(t,e,n){var r=n(\\\"e298\\\"),i=n(\\\"baff\\\").point;t.exports=function(t,e){var n=r(t),o=(n[0]+n[2])/2,s=(n[1]+n[3])/2;return i([o,s],e)}},5270:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\"),i=n(\\\"c401\\\"),o=n(\\\"2e67\\\"),s=n(\\\"2444\\\"),a=n(\\\"d925\\\"),u=n(\\\"e683\\\");function l(t){t.cancelToken&&t.cancelToken.throwIfRequested()}t.exports=function(t){l(t),t.baseURL&&!a(t.url)&&(t.url=u(t.baseURL,t.url)),t.headers=t.headers||{},t.data=i(t.data,t.headers,t.transformRequest),t.headers=r.merge(t.headers.common||{},t.headers[t.method]||{},t.headers||{}),r.forEach([\\\"delete\\\",\\\"get\\\",\\\"head\\\",\\\"post\\\",\\\"put\\\",\\\"patch\\\",\\\"common\\\"],function(e){delete t.headers[e]});var e=t.adapter||s.adapter;return e(t).then(function(e){return l(t),e.data=i(e.data,e.headers,t.transformResponse),e},function(e){return o(e)||(l(t),e&&e.response&&(e.response.data=i(e.response.data,e.response.headers,t.transformResponse))),Promise.reject(e)})}},\\\"54ee\\\":function(t,e,n){var r=n(\\\"409f\\\"),i=n(\\\"716c\\\"),o=n(\\\"feb7\\\"),s=n(\\\"00a2\\\"),a=n(\\\"f7b4\\\"),u=n(\\\"fabd\\\"),l=o.multiLineString,c=i.coordEach,h=s.collectionOf,f=o.featureCollection;function g(t,e,n,r,i){for(var o=[],s=1;s1?(r=n.x,i=n.y):a>0&&(r+=o*a,i+=s*a)}return o=t.x-r,s=t.y-i,o*o+s*s}function s(t,e){for(var n,r=t[0],o=[r],s=1,a=t.length;se&&(o.push(n),r=n);return r!==n&&o.push(n),o}function a(t,e,n,r,i){for(var s,u=r,l=e+1;lu&&(s=l,u=c)}u>r&&(s-e>1&&a(t,e,s,r,i),i.push(t[s]),n-s>1&&a(t,s,n,r,i))}function u(t,e){var n=t.length-1,r=[t[0]];return a(t,0,n,e,r),r.push(t[n]),r}function l(t,e,n){if(t.length<=2)return t;var r=void 0!==e?e*e:1;return t=n?t:s(t,r),t=u(t,r),t}r=function(){return l}.call(e,n,e,t),void 0===r||(t.exports=r)})()},5664:function(t,e,n){\\\"use strict\\\";function r(t,e,n){n=n||2;var r,o,a,u,l,c,f,g=e&&e.length,d=g?e[0]*n:t.length,p=i(t,0,d,n,!0),v=[];if(!p||p.next===p.prev)return v;if(g&&(p=h(t,e,p,n)),t.length>80*n){r=a=t[0],o=u=t[1];for(var y=n;ya&&(a=l),c>u&&(u=c);f=Math.max(a-r,u-o),f=0!==f?1/f:0}return s(p,v,n,r,o,f),v}function i(t,e,n,r,i){var o,s;if(i===R(t,e,n,r)>0)for(o=e;o=e;o-=r)s=_(o,t[o],t[o+1],s);return s&&b(s,s.next)&&(L(s),s=s.next),s}function o(t,e){if(!t)return t;e||(e=t);var n,r=t;do{if(n=!1,r.steiner||!b(r,r.next)&&0!==w(r.prev,r,r.next))r=r.next;else{if(L(r),r=e=r.prev,r===r.next)break;n=!0}}while(n||r!==e);return e}function s(t,e,n,r,i,h,f){if(t){!f&&h&&p(t,r,i,h);var g,d,v=t;while(t.prev!==t.next)if(g=t.prev,d=t.next,h?u(t,r,i,h):a(t))e.push(g.i/n),e.push(t.i/n),e.push(d.i/n),L(t),t=d.next,v=d.next;else if(t=d,t===v){f?1===f?(t=l(t,e,n),s(t,e,n,r,i,h,2)):2===f&&c(t,e,n,r,i,h):s(o(t),e,n,r,i,h,1);break}}}function a(t){var e=t.prev,n=t,r=t.next;if(w(e,n,r)>=0)return!1;var i=t.next.next;while(i!==t.prev){if(x(e.x,e.y,n.x,n.y,r.x,r.y,i.x,i.y)&&w(i.prev,i,i.next)>=0)return!1;i=i.next}return!0}function u(t,e,n,r){var i=t.prev,o=t,s=t.next;if(w(i,o,s)>=0)return!1;var a=i.xo.x?i.x>s.x?i.x:s.x:o.x>s.x?o.x:s.x,c=i.y>o.y?i.y>s.y?i.y:s.y:o.y>s.y?o.y:s.y,h=y(a,u,e,n,r),f=y(l,c,e,n,r),g=t.prevZ,d=t.nextZ;while(g&&g.z>=h&&d&&d.z<=f){if(g!==t.prev&&g!==t.next&&x(i.x,i.y,o.x,o.y,s.x,s.y,g.x,g.y)&&w(g.prev,g,g.next)>=0)return!1;if(g=g.prevZ,d!==t.prev&&d!==t.next&&x(i.x,i.y,o.x,o.y,s.x,s.y,d.x,d.y)&&w(d.prev,d,d.next)>=0)return!1;d=d.nextZ}while(g&&g.z>=h){if(g!==t.prev&&g!==t.next&&x(i.x,i.y,o.x,o.y,s.x,s.y,g.x,g.y)&&w(g.prev,g,g.next)>=0)return!1;g=g.prevZ}while(d&&d.z<=f){if(d!==t.prev&&d!==t.next&&x(i.x,i.y,o.x,o.y,s.x,s.y,d.x,d.y)&&w(d.prev,d,d.next)>=0)return!1;d=d.nextZ}return!0}function l(t,e,n){var r=t;do{var i=r.prev,o=r.next.next;!b(i,o)&&I(i,r,r.next,o)&&C(i,o)&&C(o,i)&&(e.push(i.i/n),e.push(r.i/n),e.push(o.i/n),L(r),L(r.next),r=t=o),r=r.next}while(r!==t);return r}function c(t,e,n,r,i,a){var u=t;do{var l=u.next.next;while(l!==u.prev){if(u.i!==l.i&&E(u,l)){var c=M(u,l);return u=o(u,u.next),c=o(c,c.next),s(u,e,n,r,i,a),void s(c,e,n,r,i,a)}l=l.next}u=u.next}while(u!==t)}function h(t,e,n,r){var s,a,u,l,c,h=[];for(s=0,a=e.length;s=r.next.y&&r.next.y!==r.y){var a=r.x+(o-r.y)*(r.next.x-r.x)/(r.next.y-r.y);if(a<=i&&a>s){if(s=a,a===i){if(o===r.y)return r;if(o===r.next.y)return r.next}n=r.x=r.x&&r.x>=c&&i!==r.x&&x(on.x)&&C(r,t)&&(n=r,f=u)),r=r.next;return n}function p(t,e,n,r){var i=t;do{null===i.z&&(i.z=y(i.x,i.y,e,n,r)),i.prevZ=i.prev,i.nextZ=i.next,i=i.next}while(i!==t);i.prevZ.nextZ=null,i.prevZ=null,v(i)}function v(t){var e,n,r,i,o,s,a,u,l=1;do{n=t,t=null,o=null,s=0;while(n){for(s++,r=n,a=0,e=0;e0||u>0&&r)0!==a&&(0===u||!r||n.z<=r.z)?(i=n,n=n.nextZ,a--):(i=r,r=r.nextZ,u--),o?o.nextZ=i:t=i,i.prevZ=o,o=i;n=r}o.nextZ=null,l*=2}while(s>1);return t}function y(t,e,n,r,i){return t=32767*(t-n)*i,e=32767*(e-r)*i,t=16711935&(t|t<<8),t=252645135&(t|t<<4),t=858993459&(t|t<<2),t=1431655765&(t|t<<1),e=16711935&(e|e<<8),e=252645135&(e|e<<4),e=858993459&(e|e<<2),e=1431655765&(e|e<<1),t|e<<1}function m(t){var e=t,n=t;do{e.x=0&&(t-s)*(r-a)-(n-s)*(e-a)>=0&&(n-s)*(o-a)-(i-s)*(r-a)>=0}function E(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!N(t,e)&&C(t,e)&&C(e,t)&&S(t,e)}function w(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function b(t,e){return t.x===e.x&&t.y===e.y}function I(t,e,n,r){return!!(b(t,e)&&b(n,r)||b(t,r)&&b(n,e))||w(t,e,n)>0!==w(t,e,r)>0&&w(n,r,t)>0!==w(n,r,e)>0}function N(t,e){var n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&I(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}function C(t,e){return w(t.prev,t,t.next)<0?w(t,e,t.next)>=0&&w(t,t.prev,e)>=0:w(t,e,t.prev)<0||w(t,t.next,e)<0}function S(t,e){var n=t,r=!1,i=(t.x+e.x)/2,o=(t.y+e.y)/2;do{n.y>o!==n.next.y>o&&n.next.y!==n.y&&i<(n.next.x-n.x)*(o-n.y)/(n.next.y-n.y)+n.x&&(r=!r),n=n.next}while(n!==t);return r}function M(t,e){var n=new P(t.i,t.x,t.y),r=new P(e.i,e.x,e.y),i=t.next,o=e.prev;return t.next=e,e.prev=t,n.next=i,i.prev=n,r.next=n,n.prev=r,o.next=r,r.prev=o,r}function _(t,e,n,r){var i=new P(t,e,n);return r?(i.next=r.next,i.prev=r,r.next.prev=i,r.next=i):(i.prev=i,i.next=i),i}function L(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function P(t,e,n){this.i=t,this.x=e,this.y=n,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}function R(t,e,n,r){for(var i=0,o=e,s=n-r;o0&&(r+=t[i-1].length,n.holes.push(r))}return n}},\\\"570b\\\":function(t,e,n){\\\"use strict\\\";e.LatLonSpherical=n(\\\"d425\\\"),e.LatLonEllipsoidal=n(\\\"6359\\\");var r=n(\\\"2e74\\\");for(var i in r)e.LatLonEllipsoidal[i]=r[i];e.LatLonVectors=n(\\\"ae04\\\"),e.Vector3d=n(\\\"9395\\\"),e.Utm=n(\\\"9d79\\\"),e.Mgrs=n(\\\"10ee\\\"),e.OsGridRef=n(\\\"0a0e\\\"),e.Dms=n(\\\"c226\\\")},\\\"595b\\\":function(t,e,n){var r=n(\\\"3863\\\").topology,i=n(\\\"e018\\\").merge,o=n(\\\"c29c\\\"),s=n(\\\"1fac\\\").geomEach,a=n(\\\"ae6f\\\");function u(t){return t.length?Array.isArray(t[0])?t[0]:Array.prototype.slice.call(t):[]}function l(t){var e={geoms:{type:\\\"GeometryCollection\\\",geometries:JSON.parse(JSON.stringify(t))}},n=r(e);return i(n,n.objects.geoms.geometries)}function c(t){for(var e=null,n=0;n0&&(o[0][0]===o[o.length-1][0]&&o[0][1]===o[o.length-1][1]||o.push(o[0]),o.length>=4&&n.push(o))}return n}function h(t){return t.geometry?t.geometry.type:t.type}t.exports=function(t,e){var n=h(t),r=o(t),f=t.properties;switch(n){case\\\"LineString\\\":case\\\"MultiLineString\\\":var g=[];return\\\"LineString\\\"===n&&(r=[r]),r.forEach(function(t){i(t,e,g)}),1===g.length?s(g[0],f):a(g,f);case\\\"Polygon\\\":return u(c(r,e),f);case\\\"MultiPolygon\\\":return l(r.map(function(t){return c(t,e)}),f);default:throw new Error(\\\"geometry \\\"+n+\\\" not supported\\\")}}},\\\"5ca1\\\":function(t,e,n){var r=n(\\\"7726\\\"),i=n(\\\"8378\\\"),o=n(\\\"32e9\\\"),s=n(\\\"2aba\\\"),a=n(\\\"9b43\\\"),u=\\\"prototype\\\",l=function(t,e,n){var c,h,f,g,d=t&l.F,p=t&l.G,v=t&l.S,y=t&l.P,m=t&l.B,x=p?r:v?r[e]||(r[e]={}):(r[e]||{})[u],E=p?i:i[e]||(i[e]={}),w=E[u]||(E[u]={});for(c in p&&(n=e),n)h=!d&&x&&void 0!==x[c],f=(h?x:n)[c],g=m&&h?a(f,r):y&&\\\"function\\\"==typeof f?a(Function.call,f):f,x&&s(x,c,f,t&l.U),E[c]!=f&&o(E,c,g),y&&w[c]!=f&&(w[c]=f)};r.core=i,l.F=1,l.G=2,l.S=4,l.P=8,l.B=16,l.W=32,l.U=64,l.R=128,t.exports=l},\\\"5cf5\\\":function(t,e,n){var r=n(\\\"8678\\\"),i=n(\\\"409f\\\"),o=n(\\\"9574\\\"),s=n(\\\"00a2\\\"),a=s.getGeom,u=s.getCoords,l=s.getGeomType;function c(t,e){var n,r=!1;for(n=0;ne[0])&&(!(t[2]e[1])&&!(t[3]0&&(u(e,c,i)||(i=c)),n>0&&r<=0&&(a(e,c,o)||(o=c)),n=r}return[i,o]}function a(t,e,n){return l(t,e,n)>=0}function u(t,e,n){return l(t,e,n)<=0}function l(t,e,n){return(e[0]-t[0])*(n[1]-t[1])-(n[0]-t[0])*(e[1]-t[1])}function c(t){return t.geometry?t.geometry.type:t.type}t.exports=function(t,e){var n,a,u,h,f=r(t),g=r(e),d=c(e);switch(d){case\\\"Polygon\\\":u=0,h=0,n=l(g[0][0],g[0][1],f);var p=s(g[0],f,n,a,u,h);u=p[0],h=p[1];break;case\\\"MultiPolygon\\\":u=0,h=0,n=l(g[0][0][0],g[0][0][1],f),g.forEach(function(t){var e=s(t[0],f,n,a,u,h);u=e[0],h=e[1]});break}return o([i.point(u),i.point(h)])}},\\\"613b\\\":function(t,e,n){var r=n(\\\"5537\\\")(\\\"keys\\\"),i=n(\\\"ca5a\\\");t.exports=function(t){return r[t]||(r[t]=i(t))}},\\\"61ca\\\":function(t,e,n){(function(e,n){t.exports=n()})(0,function(){\\\"use strict\\\";function t(t,n,i,o,s){e(t,n,i||0,o||t.length-1,s||r)}function e(t,r,i,o,s){while(o>i){if(o-i>600){var a=o-i+1,u=r-i+1,l=Math.log(a),c=.5*Math.exp(2*l/3),h=.5*Math.sqrt(l*c*(a-c)/a)*(u-a/2<0?-1:1),f=Math.max(i,Math.floor(r-u*c/a+h)),g=Math.min(o,Math.floor(r+(a-u)*c/a+h));e(t,r,f,g,s)}var d=t[r],p=i,v=o;n(t,i,r),s(t[o],d)>0&&n(t,i,o);while(p0)v--}0===s(t[i],d)?n(t,i,v):(v++,n(t,v,o)),v<=r&&(i=v+1),r<=v&&(o=v-1)}}function n(t,e,n){var r=t[e];t[e]=t[n],t[n]=r}function r(t,e){return te?1:0}return t})},\\\"61ea\\\":function(t,e,n){var r=n(\\\"00a2\\\").getCoord,i=n(\\\"feb7\\\"),o=i.point,s=i.distanceToRadians;t.exports=function(t,e,n,i){var a=Math.PI/180,u=180/Math.PI,l=r(t),c=a*l[0],h=a*l[1],f=a*n,g=s(e,i),d=Math.asin(Math.sin(h)*Math.cos(g)+Math.cos(h)*Math.sin(g)*Math.cos(f)),p=c+Math.atan2(Math.sin(f)*Math.sin(g)*Math.cos(h),Math.cos(g)-Math.sin(h)*Math.sin(d));return o([u*p,u*d])}},\\\"626a\\\":function(t,e,n){var r=n(\\\"2d95\\\");t.exports=Object(\\\"z\\\").propertyIsEnumerable(0)?Object:function(t){return\\\"String\\\"==r(t)?t.split(\\\"\\\"):Object(t)}},\\\"62e4\\\":function(t,e){t.exports=function(t){return t.webpackPolyfill||(t.deprecate=function(){},t.paths=[],t.children||(t.children=[]),Object.defineProperty(t,\\\"loaded\\\",{enumerable:!0,get:function(){return t.l}}),Object.defineProperty(t,\\\"id\\\",{enumerable:!0,get:function(){return t.i}}),t.webpackPolyfill=1),t}},6349:function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"feb7\\\"),o=n(\\\"fda4\\\"),s=r.flattenEach,a=r.featureEach,u=i.polygon,l=i.featureCollection;t.exports=function(t){var e=[];return s(t,function(t){\\\"Polygon\\\"===t.geometry.type&&a(o(t),function(n){e.push(u(n.geometry.coordinates,t.properties))})}),l(e)}},6359:function(t,e,n){\\\"use strict\\\";if(t.exports)var r=n(\\\"9395\\\");if(t.exports)var i=n(\\\"c226\\\");function o(t,e,n){if(!(this instanceof o))return new o(t,e,n);void 0===n&&(n=o.datum.WGS84),this.lat=Number(t),this.lon=Number(e),this.datum=n}o.ellipsoid={WGS84:{a:6378137,b:6356752.314245,f:1/298.257223563},Airy1830:{a:6377563.396,b:6356256.909,f:1/299.3249646},AiryModified:{a:6377340.189,b:6356034.448,f:1/299.3249646},Bessel1841:{a:6377397.155,b:6356078.962818,f:1/299.1528128},Clarke1866:{a:6378206.4,b:6356583.8,f:1/294.978698214},Clarke1880IGN:{a:6378249.2,b:6356515,f:1/293.466021294},GRS80:{a:6378137,b:6356752.31414,f:1/298.257222101},Intl1924:{a:6378388,b:6356911.946,f:1/297},WGS72:{a:6378135,b:6356750.5,f:1/298.26}},o.datum={ED50:{ellipsoid:o.ellipsoid.Intl1924,transform:[89.5,93.8,123.1,-1.2,0,0,.156]},Irl1975:{ellipsoid:o.ellipsoid.AiryModified,transform:[-482.53,130.596,-564.557,-8.15,-1.042,-.214,-.631]},NAD27:{ellipsoid:o.ellipsoid.Clarke1866,transform:[8,-160,-176,0,0,0,0]},NAD83:{ellipsoid:o.ellipsoid.GRS80,transform:[1.004,-1.91,-.515,-.0015,.0267,34e-5,.011]},NTF:{ellipsoid:o.ellipsoid.Clarke1880IGN,transform:[168,60,-320,0,0,0,0]},OSGB36:{ellipsoid:o.ellipsoid.Airy1830,transform:[-446.448,125.157,-542.06,20.4894,-.1502,-.247,-.8421]},Potsdam:{ellipsoid:o.ellipsoid.Bessel1841,transform:[-582,-105,-414,-8.3,1.04,.35,-3.08]},TokyoJapan:{ellipsoid:o.ellipsoid.Bessel1841,transform:[148,-507,-685,0,0,0,0]},WGS72:{ellipsoid:o.ellipsoid.WGS72,transform:[0,0,-4.5,-.22,0,0,.554]},WGS84:{ellipsoid:o.ellipsoid.WGS84,transform:[0,0,0,0,0,0,0]}},o.prototype.convertDatum=function(t){var e=this,n=null;if(e.datum==o.datum.WGS84&&(n=t.transform),t==o.datum.WGS84){n=[];for(var r=0;r<7;r++)n[r]=-e.datum.transform[r]}null==n&&(e=this.convertDatum(o.datum.WGS84),n=t.transform);var i=e.toCartesian(),s=i.applyTransform(n),a=s.toLatLonE(t);return a},o.prototype.toCartesian=function(){var t=this.lat.toRadians(),e=this.lon.toRadians(),n=0,i=this.datum.ellipsoid.a,o=this.datum.ellipsoid.f,s=Math.sin(t),a=Math.cos(t),u=Math.sin(e),l=Math.cos(e),c=2*o-o*o,h=i/Math.sqrt(1-c*s*s),f=(h+n)*a*l,g=(h+n)*a*u,d=(h*(1-c)+n)*s,p=new r(f,g,d);return p},r.prototype.toLatLonE=function(t){var e=this.x,n=this.y,r=this.z,i=t.ellipsoid.a,s=t.ellipsoid.b,a=t.ellipsoid.f,u=2*a-a*a,l=u/(1-u),c=Math.sqrt(e*e+n*n),h=Math.sqrt(c*c+r*r),f=s*r/(i*c)*(1+l*s/h),g=f/Math.sqrt(1+f*f),d=g/f,p=isNaN(d)?0:Math.atan2(r+l*s*g*g*g,c-u*i*d*d*d),v=Math.atan2(n,e),y=Math.sin(p),m=(Math.cos(p),Math.sqrt(1-u*y*y),new o(p.toDegrees(),v.toDegrees(),t));return m},r.prototype.applyTransform=function(t){var e=this.x,n=this.y,i=this.z,o=t[0],s=t[1],a=t[2],u=t[3]/1e6+1,l=(t[4]/3600).toRadians(),c=(t[5]/3600).toRadians(),h=(t[6]/3600).toRadians(),f=o+e*u-n*h+i*c,g=s+e*h+n*u-i*l,d=a-e*c+n*l+i*u;return new r(f,g,d)},o.prototype.toString=function(t,e){return i.toLat(this.lat,t,e)+\\\", \\\"+i.toLon(this.lon,t,e)},void 0===Number.prototype.toRadians&&(Number.prototype.toRadians=function(){return this*Math.PI/180}),void 0===Number.prototype.toDegrees&&(Number.prototype.toDegrees=function(){return 180*this/Math.PI}),t.exports&&(t.exports=o,t.exports.Vector3d=r)},\\\"64af\\\":function(t,e){t.exports.RADIUS=6378137,t.exports.FLATTENING=1/298.257223563,t.exports.POLAR_RADIUS=6356752.3142},6821:function(t,e,n){var r=n(\\\"626a\\\"),i=n(\\\"be13\\\");t.exports=function(t){return r(i(t))}},\\\"68aa\\\":function(t,e,n){var r=n(\\\"716c\\\");t.exports=function(t){var e={MultiPoint:{coordinates:[],properties:[]},MultiLineString:{coordinates:[],properties:[]},MultiPolygon:{coordinates:[],properties:[]}},n=Object.keys(e).reduce(function(t,e){return t[e.replace(\\\"Multi\\\",\\\"\\\")]=e,t},{});function i(t,n,r){r?e[n].coordinates=e[n].coordinates.concat(t.geometry.coordinates):e[n].coordinates.push(t.geometry.coordinates),e[n].properties.push(t.properties)}return r.featureEach(t,function(t){t.geometry&&(e[t.geometry.type]?i(t,t.geometry.type,!0):n[t.geometry.type]&&i(t,n[t.geometry.type],!1))}),{type:\\\"FeatureCollection\\\",features:Object.keys(e).filter(function(t){return e[t].coordinates.length}).sort().map(function(t){return{type:\\\"Feature\\\",properties:{collectedProperties:e[t].properties},geometry:{type:t,coordinates:e[t].coordinates}}})}}},6991:function(t,e,n){var r=n(\\\"0354\\\"),i=n(\\\"716c\\\"),o=i.featureEach,s=i.coordEach;function a(t){var e=[t[0],t[1]],n=[t[0],t[3]],r=[t[2],t[3]],i=[t[2],t[1]],o=[[e,i,r,n,e]];return{type:\\\"Feature\\\",bbox:t,properties:{},geometry:{type:\\\"Polygon\\\",coordinates:o}}}function u(t){var e=[1/0,1/0,-1/0,-1/0];return s(t,function(t){e[0]>t[0]&&(e[0]=t[0]),e[1]>t[1]&&(e[1]=t[1]),e[2]1?s(t,e):o(t[0],e)}function l(t){return t.geometry?t.geometry.type:t.type}t.exports=function(t,e){var n=l(t),i=r(t);if(e=e||t.properties||{},!i.length)throw new Error(\\\"polygon must contain coordinates\\\");switch(n){case\\\"Polygon\\\":return u(i,e);case\\\"MultiPolygon\\\":var o=[];return i.forEach(function(t){o.push(u(t,e))}),a(o);default:throw new Error(\\\"geom \\\"+n+\\\" not supported\\\")}}},\\\"77f1\\\":function(t,e,n){var r=n(\\\"4588\\\"),i=Math.max,o=Math.min;t.exports=function(t,e){return t=r(t),t<0?i(t+e,0):o(t,e)}},7899:function(t,e,n){\\\"use strict\\\";t.exports=o;var r=n(\\\"92ba\\\");function i(t,e){for(var n=new Array(e+1),i=0;i0&&\\\"number\\\"!==typeof t[0]))}function l(t,e,n){var l,c;if(a(t)||a(e))return!1;if(t.prototype!==e.prototype)return!1;if(o(t))return!!o(e)&&(t=r.call(t),e=r.call(e),s(t,e,n));if(u(t)){if(!u(e))return!1;if(t.length!==e.length)return!1;for(l=0;l=0;l--)if(h[l]!=f[l])return!1;for(l=h.length-1;l>=0;l--)if(c=h[l],!s(t[c],e[c],n))return!1;return typeof t===typeof e}},\\\"803b\\\":function(t,e,n){var r=n(\\\"feb7\\\").lineString,i=n(\\\"e868\\\");t.exports=function(t,e,n){var o;if(\\\"Feature\\\"===n.type)o=n.geometry.coordinates;else{if(\\\"LineString\\\"!==n.type)throw new Error(\\\"input must be a LineString Feature or Geometry\\\");o=n.coordinates}var s,a=i(n,t),u=i(n,e);s=a.properties.index<=u.properties.index?[a,u]:[u,a];for(var l=[s[0].geometry.coordinates],c=s[0].properties.index+1;c0&&0!==b)if(b>n[n.length-1])b-=n.length;else{var I=u.greaterNumber(b,n);0!==I&&(b-=I)}if(b!==p){var N=t.features[b];if(void 0===typeof e||N.properties[e]===v.properties[e]){var C=i(v,N);if(!C){var S=JSON.stringify(v),M=JSON.stringify(N),_=l(JSON.parse(S)),L=l(JSON.parse(M));C=a.lineStringsIntersect(_.geometry,L.geometry)}C&&(t.features[p]=r(v,N),n.push(x[w].origIndexPosition),n.sort(function(t,e){return t-e}),h.remove(x[w]),t.features.splice(b,1),m.origIndexPosition=p,h.remove(m,function(t,e){return t.origIndexPosition===e.origIndexPosition}),E=!0)}}}if(E){var P=o(v);h.insert({minX:P[0],minY:P[1],maxX:P[2],maxY:P[3],origIndexPosition:p}),p--}}return t}},8678:function(t,e,n){var r=n(\\\"00a2\\\"),i=r.getCoord,o=r.getCoords;function s(t,e,n){var r=!1;e[0][0]===e[e.length-1][0]&&e[0][1]===e[e.length-1][1]&&(e=e.slice(0,e.length-1));for(var i=0,o=e.length-1;it[1]!==l>t[1]&&t[0]<(u-s)*(t[1]-a)/(l-a)+s;h&&(r=!r)}return r}function a(t,e){return e[0]<=t[0]&&e[1]<=t[1]&&e[2]>=t[0]&&e[3]>=t[1]}t.exports=function(t,e,n){if(!t)throw new Error(\\\"point is required\\\");if(!e)throw new Error(\\\"polygon is required\\\");var r=i(t),u=o(e),l=e.geometry?e.geometry.type:e.type,c=e.bbox;if(c&&!1===a(r,c))return!1;\\\"Polygon\\\"===l&&(u=[u]);for(var h=0,f=!1;ht[1]!==l>t[1]&&t[0]<(u-s)*(t[1]-a)/(l-a)+s;h&&(r=!r)}return r}t.exports=function(t,e){var n=r.getCoord(t),o=e.geometry.coordinates;\\\"Polygon\\\"===e.geometry.type&&(o=[o]);for(var s=0,a=!1;s=g&&d===u.length-1)break;if(g>e&&0===l.length){if(c=e-g,!c)return l.push(u[d]),s(l);h=r(u[d],u[d-1])-180,f=o(u[d],c,h,a),l.push(f.geometry.coordinates)}if(g>=n)return c=n-g,c?(h=r(u[d],u[d-1])-180,f=o(u[d],c,h,a),l.push(f.geometry.coordinates),s(l)):(l.push(u[d]),s(l));if(g>=e&&l.push(u[d]),d===u.length-1)return s(l);g+=i(u[d],u[d+1],a)}return s(u[u.length-1])}},\\\"8dde\\\":function(t,e,n){var r=n(\\\"716c\\\").coordEach,i=n(\\\"feb7\\\").point;t.exports=function(t,e){var n=0,o=0,s=0;return r(t,function(t){n+=t[0],o+=t[1],s++},!0),i([n/s,o/s],e)}},\\\"8de3\\\":function(t,e){function n(t){var e=t[0],n=t[1];return[n[0]-e[0],n[1]-e[1]]}function r(t,e){return t[0]*e[1]-e[0]*t[1]}function i(t,e){return[t[0]+e[0],t[1]+e[1]]}function o(t,e){return[t[0]-e[0],t[1]-e[1]]}function s(t,e){return[t*e[0],t*e[1]]}function a(t,e){var a=t[0],u=n(t),l=e[0],c=n(e),h=r(u,c),f=o(l,a),g=r(f,c),d=g/h,p=i(a,s(d,u));return p}function u(t,e){var i=n(t),o=n(e);return 0===r(i,o)}function l(t,e){return!u(t,e)&&a(t,e)}t.exports=l},\\\"8df4\\\":function(t,e,n){\\\"use strict\\\";var r=n(\\\"7a77\\\");function i(t){if(\\\"function\\\"!==typeof t)throw new TypeError(\\\"executor must be a function.\\\");var e;this.promise=new Promise(function(t){e=t});var n=this;t(function(t){n.reason||(n.reason=new r(t),e(n.reason))})}i.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},i.source=function(){var t,e=new i(function(e){t=e});return{token:e,cancel:t}},t.exports=i},\\\"8e19\\\":function(t,e,n){!function(t,n){n(e)}(0,function(t){\\\"use strict\\\";function e(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])}function n(){}function r(){}function i(){}function o(){}function s(){}function a(){}function u(){}function l(t){this.name=\\\"RuntimeException\\\",this.message=t,this.stack=(new Error).stack,Error.call(this,t)}function c(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t}function h(){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 r=arguments[0],i=arguments[1],o=arguments[2];this.x=r,this.y=i,this.z=o}}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 r(\\\"only 2 or 3 dimensions may be specified\\\");this.dimensionsToTest=t}}function p(){}function v(){}function y(t){this.message=t||\\\"\\\"}function m(){}function x(t){this.message=t||\\\"\\\"}function E(t){this.message=t||\\\"\\\"}function w(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function b(){if(w.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 I(){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 I){var e=arguments[0];this.init(e)}}else if(2===arguments.length){var n=arguments[0],r=arguments[1];this.init(n.x,r.x,n.y,r.y)}else if(4===arguments.length){var i=arguments[0],o=arguments[1],s=arguments[2],a=arguments[3];this.init(i,o,s,a)}}function N(){}function C(){N.call(this,\\\"Projective point not representable on the Cartesian plane.\\\")}function S(){}function M(t,e){return t.interfaces_&&t.interfaces_().indexOf(e)>-1}function _(){}function L(t){this.str=t}function P(t){this.value=t}function R(){}function T(){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 T){var e=arguments[0];this.init(e)}else if(\\\"string\\\"==typeof arguments[0]){var n=arguments[0];T.call(this,T.parse(n))}}else if(2===arguments.length){var r=arguments[0],i=arguments[1];this.init(r,i)}}function O(){}function A(){}function D(){}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 r=arguments[0],i=arguments[1];this.x=r.y*i.w-i.y*r.w,this.y=i.x*r.w-r.x*i.w,this.w=r.x*i.y-i.x*r.y}else if(arguments[0]instanceof g&&arguments[1]instanceof g){var o=arguments[0],s=arguments[1];this.x=o.y-s.y,this.y=s.x-o.x,this.w=o.x*s.y-s.x*o.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 c=arguments[0],h=arguments[1],f=arguments[2],d=arguments[3],p=c.y-h.y,v=h.x-c.x,y=c.x*h.y-h.x*c.y,m=f.y-d.y,x=d.x-f.x,E=f.x*d.y-d.x*f.y;this.x=v*E-x*y,this.y=m*y-p*E,this.w=p*x-m*v}}function k(){}function G(){}function V(){this.envelope=null,this.factory=null,this.SRID=null,this.userData=null;var t=arguments[0];this.factory=t,this.SRID=t.getSRID()}function q(){}function B(){}function z(){}function j(){}function U(){}function X(){}function Y(){}function W(){}function H(){}function J(){}function Z(){}function K(){}function $(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function Q(t){return null==t?ts: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 rt(t){return null==t?null:t.right}function it(){this.root_=null,this.size_=0}function ot(){}function st(){}function at(){this.array_=[],arguments[0]instanceof v&&this.addAll(arguments[0])}function ut(){}function lt(){}function ct(){}function ht(){}function ft(){this.geometries=null;var t=arguments[0],e=arguments[1];if(V.call(this,e),null===t&&(t=[]),V.hasNullElements(t))throw new r(\\\"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,B.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 yt(){}function mt(){}function xt(){}function Et(){}function wt(){}function bt(){}function It(){}function Nt(){this.points=null;var t=arguments[0],e=arguments[1];V.call(this,e),this.init(t)}function Ct(){}function St(){this.coordinates=null;var t=arguments[0],e=arguments[1];V.call(this,e),this.init(t)}function Mt(){}function _t(){this.shell=null,this.holes=null;var t=arguments[0],e=arguments[1],n=arguments[2];if(V.call(this,n),null===t&&(t=this.getFactory().createLinearRing()),null===e&&(e=[]),V.hasNullElements(e))throw new r(\\\"holes must not contain null elements\\\");if(t.isEmpty()&&V.hasNonEmptyElements(e))throw new r(\\\"shell is empty but holes are not\\\");this.shell=t,this.holes=e}function Lt(){var t=arguments[0],e=arguments[1];ft.call(this,t,e)}function Pt(){if(arguments[0]instanceof g&&arguments[1]instanceof re){var t=arguments[0],e=arguments[1];Pt.call(this,e.getCoordinateSequenceFactory().create(t),e)}else if(M(arguments[0],A)&&arguments[1]instanceof re){var n=arguments[0],r=arguments[1];Nt.call(this,n,r),this.validateConstruction()}}function Rt(){var t=arguments[0],e=arguments[1];ft.call(this,t,e)}function Tt(){if(this.factory=null,this.isUserDataCopied=!1,0===arguments.length);else if(1===arguments.length){var t=arguments[0];this.factory=t}}function Ot(){}function At(){}function Dt(){}function Ft(){}function kt(){if(this.dimension=3,this.coordinates=null,1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];kt.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 jt(t){return this.has(t)?this._values[rs]: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(rs=t.length;rs--&&!Vt(t[rs],e););else rs=t.indexOf(e);return rs>-1}function Xt(t){return Ut.call(this,this._keys,t)}function Yt(t,e){return this.has(t)?this._values[rs]=e:this._values[this._keys.push(t)-1]=e,this}function Wt(){(this._keys||0).length=this._values.length=0}function Ht(){return Kt(this._itp,this._keys)}function Jt(){return Kt(this._itp,this._values)}function Zt(){return Kt(this._itp,this._keys,this._values)}function Kt(t,e,n){var r=[0],i=!1;return t.push(r),{next:function(){var o,s=r[0];return!i&&s1,\\\"Node capacity must be greater than 1\\\"),this.nodeCapacity=t}}function qe(){}function Be(){}function ze(){if(0===arguments.length)ze.call(this,ze.DEFAULT_NODE_CAPACITY);else if(1===arguments.length){var t=arguments[0];Ve.call(this,t)}}function je(){var t=arguments[0];ke.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],r=arguments[3];this.segString=t,this.coord=new g(e),this.segmentIndex=n,this.segmentOctant=r,this._isInterior=!e.equals2D(t.getCoordinate(n))}function Ye(){this.nodeMap=new it,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 He(){}function Je(){this.nodeList=new Ye(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 I,this.tempEnv2=new I,this.overlapSeg1=new he,this.overlapSeg2=new he}function Ke(){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],r=arguments[3];this.pts=t,this.start=e,this.end=n,this.context=r}function $e(){}function Qe(){}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 w,this.index=new ze,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 on(){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,on.msgWithCoord(e,n)),this.name=\\\"TopologyException\\\",this.pt=new g(n)}}function sn(){}function an(){this.findAllIntersections=!1,this.isCheckEndSegmentsOnly=!1,this.li=null,this.interiorIntersection=null,this.intSegments=null,this.intersections=new w,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 cn(){this.mapOp=null;var t=arguments[0];this.mapOp=t}function hn(){}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[hn.ON]=e}else if(arguments[0]instanceof fn){var n=arguments[0];if(this.init(n.location.length),null!==n)for(var r=0;r=0?this.setComputationPrecision(r.getPrecisionModel()):this.setComputationPrecision(i.getPrecisionModel()),this.arg=new Array(2).fill(null),this.arg[0]=new Qn(0,r,o),this.arg[1]=new Qn(1,i,o)}}function er(){this.pts=null,this._orientation=null;var t=arguments[0];this.pts=t,this._orientation=er.orientation(t)}function nr(){this.edges=new w,this.ocaMap=new it}function rr(){this.ptLocator=new _e,this.geomFact=null,this.resultGeom=null,this.graph=null,this.edgeList=new nr,this.resultPolyList=new w,this.resultLineList=new w,this.resultPointList=new w;var t=arguments[0],e=arguments[1];tr.call(this,t,e),this.graph=new In(new Rn),this.geomFact=t.getFactory()}function ir(){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 or(){this.geom=new Array(2).fill(null);var t=arguments[0],e=arguments[1];this.geom[0]=t,this.geom[1]=e}function sr(){this.factory=null,this.interiorPoint=null,this.maxWidth=0;var t=arguments[0];this.factory=t.getFactory(),this.add(t)}function ar(){this.poly=null,this.centreY=null,this.hiY=i.MAX_VALUE,this.loY=-i.MAX_VALUE;var t=arguments[0];this.poly=t,this.hiY=t.getEnvelopeInternal().getMaxY(),this.loY=t.getEnvelopeInternal().getMinY(),this.centreY=sr.avg(this.loY,this.hiY)}function ur(){this.centroid=null,this.minDistance=i.MAX_VALUE,this.interiorPoint=null;var t=arguments[0];this.centroid=t.getCentroid().getCoordinate(),this.addInterior(t),null===this.interiorPoint&&this.addEndpoints(t)}function lr(){this.centroid=null,this.minDistance=i.MAX_VALUE,this.interiorPoint=null;var t=arguments[0];this.centroid=t.getCentroid().getCoordinate(),this.add(t)}function cr(){this.tempEnv1=new I,this.selectedSegment=new he}function hr(){this.items=new w,this.subnode=[null,null]}function fr(){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 gr(){}function dr(t,e){var n,r,i,o,s={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(o||(n=e<0||1/e<0,isFinite(e)||(o=s[t],n&&(o.d+=1<=2;)r++,i/=2;for(;i<1&&r>0;)r--,i*=2;r<=0&&(i/=2),32===t&&r>254&&(o={d:n?255:127,c:128,b:0,a:0},r=Math.pow(2,a)-1,i=0)}return r}function pr(){this.pt=0,this.level=0,this.interval=null;var t=arguments[0];this.computeKey(t)}function vr(){hr.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 yr(){}function mr(){hr.apply(this)}function xr(){this.root=null,this.minExtent=1,this.root=new mr}function Er(){}function wr(){this.ring=null,this.tree=null,this.crossings=0,this.interval=new fr;var t=arguments[0];this.ring=t,this.buildIndex()}function br(){cr.apply(this),this.mcp=null,this.p=null;var t=arguments[0],e=arguments[1];this.mcp=t,this.p=e}function Ir(){}function Nr(){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 Cr(){this.input=null,this.extremalPts=null,this.centre=null,this.radius=0;var t=arguments[0];this.input=t}function Sr(){if(this.inputGeom=null,this.isConvex=null,this.convexHullPts=null,this.minBaseSeg=new he,this.minWidthPt=null,this.minPtIndex=null,this.minWidth=0,1===arguments.length){var t=arguments[0];Sr.call(this,t,!1)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.inputGeom=e,this.isConvex=n}}function Mr(){this.inputGeom=null,this.distanceTolerance=null;var t=arguments[0];this.inputGeom=t}function _r(){xe.apply(this),this.distanceTolerance=null;var t=arguments[0];this.distanceTolerance=t}function Lr(){this._orig=null,this._sym=null,this._next=null;var t=arguments[0];this._orig=t}function Pr(){this._isMarked=!1;var t=arguments[0];Lr.call(this,t)}function Rr(){this.vertexMap=new te}function Tr(){this._isStart=!1;var t=arguments[0];Pr.call(this,t)}function Or(){Rr.apply(this)}function Ar(){this.result=null,this.factory=null,this.graph=null,this.lines=new w,this.nodeEdgeStack=new pe,this.ringStartEdge=null,this.graph=new Or}function Dr(){this.items=new w,this.subnode=new Array(4).fill(null)}function Fr(){this.pt=new g,this.level=0,this.env=null;var t=arguments[0];this.computeKey(t)}function kr(){Dr.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 Gr(){Dr.apply(this)}function Vr(){this.root=null,this.minExtent=1,this.root=new Gr}function qr(t){this.geometryFactory=t||new re}function Br(t){this.geometryFactory=t||new re,this.precisionModel=this.geometryFactory.getPrecisionModel(),this.parser=new qr(this.geometryFactory)}function zr(){this.parser=new qr(this.geometryFactory)}function jr(t){this.geometryFactory=t||new re,this.precisionModel=this.geometryFactory.getPrecisionModel(),this.parser=new ie(this.geometryFactory)}function Ur(t){return[t.x,t.y]}function Xr(t,e){this.geometryFactory=t||new re,this.ol=e||\\\"undefined\\\"!=typeof ol&&ol}function Yr(){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];Yr.call(this,t,e,0,0)}else if(4===arguments.length){var n=arguments[0],r=arguments[1];arguments[2],arguments[3],this.noder=n,this.scaleFactor=r,this.isScaled=!this.isIntegerPrecision()}}function Wr(){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];this.inputGeom=e,this.isClosedEndpointsInInterior=!n.isInBoundary(2)}}function Hr(){this.pt=null,this.isClosed=null,this.degree=null;var t=arguments[0];this.pt=t,this.isClosed=!1,this.degree=0}function Jr(){if(this.quadrantSegments=Jr.DEFAULT_QUADRANT_SEGMENTS,this.endCapStyle=Jr.CAP_ROUND,this.joinStyle=Jr.JOIN_ROUND,this.mitreLimit=Jr.DEFAULT_MITRE_LIMIT,this._isSingleSided=!1,this.simplifyFactor=Jr.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 r=arguments[0],i=arguments[1],o=arguments[2],s=arguments[3];this.setQuadrantSegments(r),this.setEndCapStyle(i),this.setJoinStyle(o),this.setMitreLimit(s)}}function Zr(){this.minIndex=-1,this.minCoord=null,this.minDe=null,this.orientedDe=null}function Kr(){this.array_=[]}function $r(){this.finder=null,this.dirEdgeList=new w,this.nodes=new w,this.rightMostCoord=null,this.env=null,this.finder=new Zr}function Qr(){this.inputLine=null,this.distanceTol=null,this.isDeleted=null,this.angleOrientation=ce.COUNTERCLOCKWISE;var t=arguments[0];this.inputLine=t}function ti(){this.ptList=null,this.precisionModel=null,this.minimimVertexDistance=0,this.ptList=new w}function ei(){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 he,this.seg1=new he,this.offset0=new he,this.offset1=new he,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()===Jr.JOIN_ROUND&&(this.closingSegLengthFactor=ei.MAX_CLOSING_SEG_LEN_FACTOR),this.init(n)}function ni(){this.distance=0,this.precisionModel=null,this.bufParams=null;var t=arguments[0],e=arguments[1];this.precisionModel=t,this.bufParams=e}function ri(){this.subgraphs=null,this.seg=new he,this.cga=new ce;var t=arguments[0];this.subgraphs=t}function ii(){this.upwardSeg=null,this.leftDepth=null;var t=arguments[0],e=arguments[1];this.upwardSeg=new he(t),this.leftDepth=e}function oi(){this.inputGeom=null,this.distance=null,this.curveBuilder=null,this.curveList=new w;var t=arguments[0],e=arguments[1],n=arguments[2];this.inputGeom=t,this.distance=e,this.curveBuilder=n}function si(){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 ai(){this.bufParams=null,this.workingPrecisionModel=null,this.workingNoder=null,this.geomFact=null,this.graph=null,this.edgeList=new nr;var t=arguments[0];this.bufParams=t}function ui(){this.li=new ae,this.segStrings=null;var t=arguments[0];this.segStrings=t}function li(){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 r(\\\"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 ci(){this.index=null;var t=arguments[0];this.index=t}function hi(){cr.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 fi(){this.li=null,this.interiorIntersections=null;var t=arguments[0];this.li=t,this.interiorIntersections=new w}function gi(){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 di(){if(this.argGeom=null,this.distance=null,this.bufParams=new Jr,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 pi(){this.comps=null;var t=arguments[0];this.comps=t}function vi(){if(this.component=null,this.segIndex=null,this.pt=null,2===arguments.length){var t=arguments[0],e=arguments[1];vi.call(this,t,vi.INSIDE_AREA,e)}else if(3===arguments.length){var n=arguments[0],r=arguments[1],i=arguments[2];this.component=n,this.segIndex=r,this.pt=i}}function yi(){this.pts=null;var t=arguments[0];this.pts=t}function mi(){this.locations=null;var t=arguments[0];this.locations=t}function xi(){if(this.geom=null,this.terminateDistance=0,this.ptLocator=new _e,this.minDistanceLocation=null,this.minDistance=i.MAX_VALUE,2===arguments.length){var t=arguments[0],e=arguments[1];xi.call(this,t,e,0)}else if(3===arguments.length){var n=arguments[0],r=arguments[1],o=arguments[2];this.geom=new Array(2).fill(null),this.geom[0]=n,this.geom[1]=r,this.terminateDistance=o}}function Ei(){this.factory=null,this.directedEdges=new w,this.coordinates=null;var t=arguments[0];this.factory=t}function wi(){this._isMarked=!1,this._isVisited=!1,this.data=null}function bi(){wi.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],r=arguments[3];this.from=t,this.to=e,this.edgeDirection=r,this.p0=t.getCoordinate(),this.p1=n;var i=this.p1.x-this.p0.x,o=this.p1.y-this.p0.y;this.quadrant=$e.quadrant(i,o),this.angle=Math.atan2(o,i)}function Ii(){var t=arguments[0],e=arguments[1],n=arguments[2],r=arguments[3];bi.call(this,t,e,n,r)}function Ni(){if(wi.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 Ci(){this.outEdges=new w,this.sorted=!1}function Si(){if(wi.apply(this),this.pt=null,this.deStar=null,1===arguments.length){var t=arguments[0];Si.call(this,t,new Ci)}else if(2===arguments.length){var e=arguments[0],n=arguments[1];this.pt=e,this.deStar=n}}function Mi(){Ni.apply(this),this.line=null;var t=arguments[0];this.line=t}function _i(){this.nodeMap=new it}function Li(){this.edges=new $,this.dirEdges=new $,this.nodeMap=new _i}function Pi(){Li.apply(this)}function Ri(){this.graph=new Pi,this.mergedLineStrings=null,this.factory=null,this.edgeStrings=null}function Ti(){this.edgeRing=null,this.next=null,this.label=-1;var t=arguments[0],e=arguments[1],n=arguments[2],r=arguments[3];bi.call(this,t,e,n,r)}function Oi(){Ni.apply(this),this.line=null;var t=arguments[0];this.line=t}function Ai(){this.geometryFactory=new re,this.geomGraph=null,this.disconnectedRingcoord=null;var t=arguments[0];this.geomGraph=t}function Di(){}function Fi(){if(this.edgeEnds=new w,1===arguments.length){var t=arguments[0];Fi.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 ki(){Ln.apply(this)}function Gi(){var t=arguments[0],e=arguments[1];mn.call(this,t,e)}function Vi(){bn.apply(this)}function qi(){this.nodes=new xn(new Vi)}function Bi(){this.li=new ae,this.geomGraph=null,this.nodeGraph=new qi,this.invalidPoint=null;var t=arguments[0];this.geomGraph=t}function zi(){this.graph=null,this.rings=new w,this.totalEnv=new I,this.index=null,this.nestedPt=null;var t=arguments[0];this.graph=t}function ji(){if(this.errorType=null,this.pt=null,1===arguments.length){var t=arguments[0];ji.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 Ui(){this.parentGeometry=null,this.isSelfTouchingRingFormingHoleValid=!1,this.validErr=null;var t=arguments[0];this.parentGeometry=t}function Xi(){this.factory=null,this.deList=new w,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 Yi(){}function Wi(){Li.apply(this),this.factory=null;var t=arguments[0];this.factory=t}function Hi(){if(this.lineStringAdder=new Ji(this),this.graph=null,this.dangles=new w,this.cutEdges=new w,this.invalidRingLines=new w,this.holeList=null,this.shellList=null,this.polyList=null,this.isCheckingRingsValid=!0,this.extractOnlyPolygonal=null,this.geomFactory=null,0===arguments.length)Hi.call(this,!1);else if(1===arguments.length){var t=arguments[0];this.extractOnlyPolygonal=t}}function Ji(){this.p=null;var t=arguments[0];this.p=t}function Zi(){this.li=new ae,this.ptLocator=new _e,this.arg=null,this.nodes=new xn(new Vi),this.im=null,this.isolatedEdges=new w,this.invalidPoint=null;var t=arguments[0];this.arg=t}function Ki(){this.rectEnv=null;var t=arguments[0];this.rectEnv=t.getEnvelopeInternal()}function $i(){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 Qi(){this._isDone=!1}function to(){this.rectangle=null,this.rectEnv=null;var t=arguments[0];this.rectangle=t,this.rectEnv=t.getEnvelopeInternal()}function eo(){Qi.apply(this),this.rectEnv=null,this._intersects=!1;var t=arguments[0];this.rectEnv=t}function no(){Qi.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 ro(){Qi.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 $i(this.rectEnv)}function io(){if(this._relate=null,2===arguments.length){var t=arguments[0],e=arguments[1];tr.call(this,t,e),this._relate=new Zi(this.arg)}else if(3===arguments.length){var n=arguments[0],r=arguments[1],i=arguments[2];tr.call(this,n,r,i),this._relate=new Zi(this.arg)}}function oo(){this.geomFactory=null,this.skipEmpty=!1,this.inputGeoms=null;var t=arguments[0];this.geomFactory=oo.extractFactory(t),this.inputGeoms=t}function so(){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 ao(){this.sortIndex=-1,this.comps=null;var t=arguments[0],e=arguments[1];this.sortIndex=t,this.comps=e}function uo(){this.inputPolys=null,this.geomFactory=null;var t=arguments[0];this.inputPolys=t,null===this.inputPolys&&(this.inputPolys=new w)}function lo(){if(this.polygons=new w,this.lines=new w,this.points=new w,this.geomFact=null,1===arguments.length){if(M(arguments[0],v)){var t=arguments[0];this.extract(t)}else if(arguments[0]instanceof V){var e=arguments[0];this.extract(e)}}else if(2===arguments.length){var n=arguments[0],r=arguments[1];this.geomFact=r,this.extract(n)}}function co(){Tt.CoordinateOperation.apply(this),this.targetPM=null,this.removeCollapsed=!0;var t=arguments[0],e=arguments[1];this.targetPM=t,this.removeCollapsed=e}function ho(){this.targetPM=null,this.removeCollapsed=!0,this.changePrecisionModel=!1,this.isPointwise=!1;var t=arguments[0];this.targetPM=t}function fo(){this.pts=null,this.usePt=null,this.distanceTolerance=null,this.seg=new he;var t=arguments[0];this.pts=t}function go(){this.inputGeom=null,this.distanceTolerance=null,this.isEnsureValidTopology=!0;var t=arguments[0];this.inputGeom=t}function po(){xe.apply(this),this.isEnsureValidTopology=!0,this.distanceTolerance=null;var t=arguments[0],e=arguments[1];this.isEnsureValidTopology=t,this.distanceTolerance=e}function vo(){if(this.parent=null,this.index=null,2===arguments.length){var t=arguments[0],e=arguments[1];vo.call(this,t,e,null,-1)}else if(4===arguments.length){var n=arguments[0],r=arguments[1],i=arguments[2],o=arguments[3];he.call(this,n,r),this.parent=i,this.index=o}}function yo(){if(this.parentLine=null,this.segs=null,this.resultSegs=new w,this.minimumSize=null,1===arguments.length){var t=arguments[0];yo.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 mo(){this.index=new Vr}function xo(){this.querySeg=null,this.items=new w;var t=arguments[0];this.querySeg=t}function Eo(){this.li=new ae,this.inputIndex=new mo,this.outputIndex=new mo,this.line=null,this.linePts=null,this.distanceTolerance=0;var t=arguments[0],e=arguments[1];this.inputIndex=t,this.outputIndex=e}function wo(){this.inputIndex=new mo,this.outputIndex=new mo,this.distanceTolerance=0}function bo(){this.inputGeom=null,this.lineSimplifier=new wo,this.linestringMap=null;var t=arguments[0];this.inputGeom=t}function Io(){xe.apply(this),this.linestringMap=null;var t=arguments[0];this.linestringMap=t}function No(){this.tps=null;var t=arguments[0];this.tps=t}function Co(){this.seg=null,this.segLen=null,this.splitPt=null,this.minimumLen=0;var t=arguments[0];this.seg=t,this.segLen=t.getLength()}function So(){}function Mo(){}function _o(){}function Lo(){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 r=arguments[0],i=arguments[1],o=arguments[2];this.p=new g(r,i,o)}}function Po(){this._isOnConstraint=null,this.constraint=null;var t=arguments[0];Lo.call(this,t)}function Ro(){this._rot=null,this.vertex=null,this.next=null,this.data=null}function To(){this.subdiv=null,this.isUsingTolerance=!1;var t=arguments[0];this.subdiv=t,this.isUsingTolerance=t.getTolerance()>0}function Oo(){}function Ao(){this.subdiv=null,this.lastEdge=null;var t=arguments[0];this.subdiv=t,this.init()}function Do(){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 he){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 he(e)}}else if(2===arguments.length){var n=arguments[0],r=arguments[1];l.call(this,Do.msgWithSpatial(n,r)),this.seg=new he(r)}}function Fo(){}function ko(){this.visitedKey=0,this.quadEdges=new w,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 he,this.triEdges=new Array(3).fill(null);var t=arguments[0],e=arguments[1];this.tolerance=e,this.edgeCoincidenceTolerance=e/ko.EDGE_COINCIDENCE_TOL_FACTOR,this.createFrame(t),this.startingEdge=this.initSubdiv(),this.locator=new Ao(this)}function Go(){}function Vo(){this.triList=new w}function qo(){this.triList=new w}function Bo(){this.coordList=new b,this.triCoords=new w}function zo(){if(this.ls=null,this.data=null,2===arguments.length){var t=arguments[0],e=arguments[1];this.ls=new he(t,e)}else if(3===arguments.length){var n=arguments[0],r=arguments[1],i=arguments[2];this.ls=new he(n,r),this.data=i}else if(6===arguments.length){var o=arguments[0],s=arguments[1],a=arguments[2],u=arguments[3],l=arguments[4],c=arguments[5];zo.call(this,new g(o,s,a),new g(u,l,c))}else if(7===arguments.length){var h=arguments[0],f=arguments[1],d=arguments[2],p=arguments[3],v=arguments[4],y=arguments[5],m=arguments[6];zo.call(this,new g(h,f,d),new g(p,v,y),m)}}function jo(){}function Uo(){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],r=arguments[1],i=arguments[2];this.p=new g(n,r),this.left=null,this.right=null,this.count=1,this.data=i}}function Xo(){if(this.root=null,this.numberOfNodes=null,this.tolerance=null,0===arguments.length)Xo.call(this,0);else if(1===arguments.length){var t=arguments[0];this.tolerance=t}}function Yo(){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 Wo(){this.initialVertices=null,this.segVertices=null,this.segments=new w,this.subdiv=null,this.incDel=null,this.convexHull=null,this.splitFinder=new Mo,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 w(t),this.tolerance=e,this.kdt=new Xo(e)}function Ho(){this.siteCoords=null,this.tolerance=0,this.subdiv=null}function Jo(){this.siteCoords=null,this.constraintLines=null,this.tolerance=0,this.subdiv=null,this.constraintVertexMap=new it}function Zo(){this.siteCoords=null,this.tolerance=0,this.subdiv=null,this.clipEnv=null,this.diagramEnv=null}function Ko(){}\\\"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,r=1 in arguments&&parseInt(Number(arguments[1]),10)||0;r=r<0?Math.max(n+r,0):Math.min(r,n);var i=2 in arguments&&void 0!==arguments[2]?parseInt(Number(arguments[2]),10)||0:n;for(i=i<0?Math.max(n+arguments[2],0):Math.min(i,n);re.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}},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,r=this.z-t.z;return Math.sqrt(e*e+n*n+r*r)},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),37*t+g.hashCode(this.y)},setCoordinate:function(t){this.x=t.x,this.y=t.y,this.z=t.z},interfaces_:function(){return[o,s,u]},getClass:function(){return g}}),g.hashCode=function(){if(1===arguments.length){var t=arguments[0],e=i.doubleToLongBits(t);return Math.trunc(e^e>>>32)}},e(d.prototype,{compare:function(t,e){var n=t,r=e,i=d.compare(n.x,r.x);if(0!==i)return i;var o=d.compare(n.y,r.y);if(0!==o)return o;if(this.dimensionsToTest<=2)return 0;var s=d.compare(n.z,r.z);return s},interfaces_:function(){return[a]},getClass:function(){return d}}),d.compare=function(t,e){return te?1:i.isNaN(t)?i.isNaN(e)?0:-1:i.isNaN(e)?1:0},g.DimensionalComparator=d,g.serialVersionUID=0x5cbf2c235c7e5800,g.NULL_ORDINATE=i.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(){},y.prototype=new Error,y.prototype.name=\\\"IndexOutOfBoundsException\\\",m.prototype=Object.create(v.prototype),m.prototype.constructor=m,m.prototype.get=function(){},m.prototype.set=function(){},m.prototype.isEmpty=function(){},x.prototype=new Error,x.prototype.name=\\\"NoSuchElementException\\\",E.prototype=new Error,E.prototype.name=\\\"OperationNotSupported\\\",w.prototype=Object.create(m.prototype),w.prototype.constructor=w,w.prototype.ensureCapacity=function(){},w.prototype.interfaces_=function(){return[m,v]},w.prototype.add=function(t){return 1===arguments.length?this.array_.push(t):this.array_.splice(arguments[0],arguments[1]),!0},w.prototype.clear=function(){this.array_=[]},w.prototype.addAll=function(t){for(var e=t.iterator();e.hasNext();)this.add(e.next());return!0},w.prototype.set=function(t,e){var n=this.array_[t];return this.array_[t]=e,n},w.prototype.iterator=function(){return new $o(this)},w.prototype.get=function(t){if(t<0||t>=this.size())throw new y;return this.array_[t]},w.prototype.isEmpty=function(){return 0===this.array_.length},w.prototype.size=function(){return this.array_.length},w.prototype.toArray=function(){for(var t=[],e=0,n=this.array_.length;e=1){var o=this.get(this.size()-1);if(o.equals2D(r))return null}w.prototype.add.call(this,r)}else if(arguments[0]instanceof Object&&\\\"boolean\\\"==typeof arguments[1]){var s=arguments[0],a=arguments[1];return this.add(s,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],c=arguments[2];if(c)for(var h=0;h=0;h--)this.add(u[h],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 y=this.get(f-1);if(y.equals2D(d))return null}if(fI&&(N=-1);for(h=b;h!==I;h+=N)this.add(x[h],E);return!0}},closeRing:function(){this.size()>0&&this.add(new g(this.get(0)),!1)},interfaces_:function(){return[]},getClass:function(){return b}}),b.coordArrayType=new Array(0).fill(null),e(I.prototype,{getArea:function(){return this.getWidth()*this.getHeight()},equals:function(t){if(!(t instanceof I))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 I;var e=this.minx>t.minx?this.minx:t.minx,n=this.miny>t.miny?this.miny:t.miny,r=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],r=arguments[1];return!this.isNull()&&n>=this.minx&&n<=this.maxx&&r>=this.miny&&r<=this.maxy}},intersects:function(){if(1===arguments.length){if(arguments[0]instanceof I){var t=arguments[0];return!this.isNull()&&!t.isNull()&&!(t.minx>this.maxx||t.maxxthis.maxy||t.maxythis.maxx||nthis.maxy||rthis.maxx&&(this.maxx=e.maxx),e.minythis.maxy&&(this.maxy=e.maxy))}}else if(2===arguments.length){var n=arguments[0],r=arguments[1];this.isNull()?(this.minx=n,this.maxx=n,this.miny=r,this.maxy=r):(nthis.maxx&&(this.maxx=n),rthis.maxy&&(this.maxy=r))}},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 I){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],r=arguments[1];return this.covers(n,r)}},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 I){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],r=arguments[1];this.init(n.x,r.x,n.y,r.y)}else if(4===arguments.length){var i=arguments[0],o=arguments[1],s=arguments[2],a=arguments[3];it.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),37*t+g.hashCode(this.maxy)},interfaces_:function(){return[o,u]},getClass:function(){return I}}),I.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 r=arguments[0],i=arguments[1],o=arguments[2],s=arguments[3],a=Math.min(o.x,s.x),u=Math.max(o.x,s.x),l=Math.min(r.x,i.x),c=Math.max(r.x,i.x);return!(l>u)&&!(cu)&&!(cn?n:t}if(Number.isInteger(arguments[2])&&Number.isInteger(arguments[0])&&Number.isInteger(arguments[1])){var r=arguments[0],i=arguments[1],o=arguments[2];return ro?o:r}},_.wrap=function(t,e){return t<0?e- -t%e:t%e},_.max=function(){if(3===arguments.length){var t=arguments[0],e=arguments[1],n=arguments[2],r=t;return e>r&&(r=e),n>r&&(r=n),r}if(4===arguments.length){var i=arguments[0],o=arguments[1],s=arguments[2],a=arguments[3];r=i;return o>r&&(r=o),s>r&&(r=s),a>r&&(r=a),r}},_.average=function(t,e){return(t+e)/2},_.LOG_10=Math.log(10),L.prototype.append=function(t){this.str+=t},L.prototype.setCharAt=function(t,e){this.str=this.str.substr(0,t)+e+this.str.substr(t+1)},L.prototype.toString=function(t){return this.str},P.prototype.intValue=function(){return this.value},P.prototype.compareTo=function(t){return this.valuet?1:0},P.isNaN=function(t){return Number.isNaN(t)},R.isWhitespace=function(t){return t<=32&&t>=0||127==t},R.toUpperCase=function(t){return t.toUpperCase()},e(T.prototype,{le:function(t){return this.hi9?(c=!0,h=\\\"9\\\"):h=\\\"0\\\"+l,s.append(h),n=n.subtract(T.valueOf(l)).multiply(T.TEN),c&&n.selfAdd(T.TEN);var f=!0,g=T.magnitude(n.hi);if(g<0&&Math.abs(g)>=a-u&&(f=!1),!f)break}return e[0]=r,s.toString()},sqr:function(){return this.multiply(this)},doubleValue:function(){return this.hi+this.lo},subtract:function(){if(arguments[0]instanceof T){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 T){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 T){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],r=arguments[1],i=null,o=null,s=null,a=null,u=null,l=null,c=null,h=null;return u=this.hi/n,l=T.SPLIT*u,i=l-u,h=T.SPLIT*n,i=l-i,o=u-i,s=h-n,c=u*n,s=h-s,a=n-s,h=i*s-c+i*a+o*s+o*a,l=(this.hi-c-h+this.lo-u*r)/n,h=u+l,this.hi=h,this.lo=u-h+l,this}},dump:function(){return\\\"DD<\\\"+this.hi+\\\", \\\"+this.lo+\\\">\\\"},divide:function(){if(arguments[0]instanceof T){var t=arguments[0],e=null,n=null,r=null,o=null,s=null,a=null,u=null,l=null;s=this.hi/t.hi,a=T.SPLIT*s,e=a-s,l=T.SPLIT*t.hi,e=a-e,n=s-e,r=l-t.hi,u=s*t.hi,r=l-r,o=t.hi-r,l=e*r-u+e*o+n*r+n*o,a=(this.hi-u-l+this.lo-s*t.lo)/t.hi,l=s+a;var c=l,h=s-l+a;return new T(c,h)}if(\\\"number\\\"==typeof arguments[0]){var f=arguments[0];return i.isNaN(f)?T.createNaN():T.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 T.valueOf(1);var e=new T(this),n=T.valueOf(1),r=Math.abs(t);if(r>1)for(;r>0;)r%2===1&&n.selfMultiply(e),r/=2,r>0&&(e=e.sqr());else n=e;return t<0?n.reciprocal():n},ceil:function(){if(this.isNaN())return T.NaN;var t=Math.ceil(this.hi),e=0;return t===this.hi&&(e=Math.ceil(this.lo)),new T(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 T){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 T.valueOf(0);if(this.isNegative())return T.NaN;var t=1/Math.sqrt(this.hi),e=this.hi*t,n=T.valueOf(e),r=this.subtract(n.sqr()),i=r.hi*(.5*t);return n.add(i)},selfAdd:function(){if(1===arguments.length){if(arguments[0]instanceof T){var t=arguments[0];return this.selfAdd(t.hi,t.lo)}if(\\\"number\\\"==typeof arguments[0]){var e=arguments[0],n=null,r=null,i=null,o=null,s=null,a=null;return i=this.hi+e,s=i-this.hi,o=i-s,o=e-s+(this.hi-o),a=o+this.lo,n=i+a,r=a+(i-n),this.hi=n+r,this.lo=r+(n-this.hi),this}}else if(2===arguments.length){var u=arguments[0],l=arguments[1],c=(n=null,r=null,null),h=null;i=null,o=null,s=null,a=null;i=this.hi+u,c=this.lo+l,s=i-this.hi,a=c-this.lo,o=i-s,h=c-a,o=u-s+(this.hi-o),h=l-a+(this.lo-h),s=o+c,n=i+s,r=s+(i-n),s=h+r;var f=n+s,g=s+(n-f);return this.hi=f,this.lo=g,this}},selfMultiply:function(){if(1===arguments.length){if(arguments[0]instanceof T){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],r=arguments[1],i=null,o=null,s=null,a=null,u=null,l=null;u=T.SPLIT*this.hi,i=u-this.hi,l=T.SPLIT*n,i=u-i,o=this.hi-i,s=l-n,u=this.hi*n,s=l-s,a=n-s,l=i*s-u+i*a+o*s+o*a+(this.hi*r+this.lo*n);var c=u+l;i=u-c;var h=l+i;return this.hi=c,this.lo=h,this}},selfSqr:function(){return this.selfMultiply(this)},floor:function(){if(this.isNaN())return T.NaN;var t=Math.floor(this.hi),e=0;return t===this.hi&&(e=Math.floor(this.lo)),new T(t,e)},negate:function(){return this.isNaN()?this:new T(-this.hi,-this.lo)},clone:function(){try{return null}catch(t){if(t instanceof CloneNotSupportedException)return null;throw t}},multiply:function(){if(arguments[0]instanceof T){var t=arguments[0];return t.isNaN()?T.createNaN():T.copy(this).selfMultiply(t)}if(\\\"number\\\"==typeof arguments[0]){var e=arguments[0];return i.isNaN(e)?T.createNaN():T.copy(this).selfMultiply(e,0)}},isNaN:function(){return i.isNaN(this.hi)},intValue:function(){return Math.trunc(this.hi)},toString:function(){var t=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),r=e[0]+1,i=n;if(\\\".\\\"===n.charAt(0))i=\\\"0\\\"+n;else if(r<0)i=\\\"0.\\\"+T.stringOfChar(\\\"0\\\",-r)+n;else if(-1===n.indexOf(\\\".\\\")){var o=r-n.length,s=T.stringOfChar(\\\"0\\\",o);i=n+s+\\\".0\\\"}return this.isNegative()?\\\"-\\\"+i:i},reciprocal:function(){var t=null,e=null,n=null,r=null,i=null,o=null,s=null,a=null;i=1/this.hi,o=T.SPLIT*i,t=o-i,a=T.SPLIT*this.hi,t=o-t,e=i-t,n=a-this.hi,s=i*this.hi,n=a-n,r=this.hi-n,a=t*n-s+t*r+e*n+e*r,o=(1-s-a-i*this.lo)/this.hi;var u=i+o,l=i-u+o;return new T(u,l)},toSciNotation:function(){if(this.isZero())return T.SCI_NOT_ZERO;var t=this.getSpecialNumberString();if(null!==t)return t;var e=new Array(1).fill(null),n=this.extractSignificantDigits(!1,e),r=T.SCI_NOT_EXPONENT_CHAR+e[0];if(\\\"0\\\"===n.charAt(0))throw new IllegalStateException(\\\"Found leading zero: \\\"+n);var i=\\\"\\\";n.length>1&&(i=n.substring(1));var o=n.charAt(0)+\\\".\\\"+i;return this.isNegative()?\\\"-\\\"+o+r:o+r},abs:function(){return this.isNaN()?T.NaN:this.isNegative()?this.negate():new T(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()?T.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,o,s]},getClass:function(){return T}}),T.sqr=function(t){return T.valueOf(t).selfMultiply(t)},T.valueOf=function(){if(\\\"string\\\"==typeof arguments[0]){var t=arguments[0];return T.parse(t)}if(\\\"number\\\"==typeof arguments[0]){var e=arguments[0];return new T(e)}},T.sqrt=function(t){return T.valueOf(t).sqrt()},T.parse=function(t){for(var e=0,n=t.length;R.isWhitespace(t.charAt(e));)e++;var r=!1;if(e=n)break;var l=t.charAt(e);if(e++,R.isDigit(l)){var c=l-\\\"0\\\";o.selfMultiply(T.TEN),o.selfAdd(c),s++}else{if(\\\".\\\"!==l){if(\\\"e\\\"===l||\\\"E\\\"===l){var h=t.substring(e);try{u=P.parseInt(h)}catch(e){throw e instanceof NumberFormatException?new NumberFormatException(\\\"Invalid exponent \\\"+h+\\\" in string \\\"+t):e}break}throw new NumberFormatException(\\\"Unexpected character '\\\"+l+\\\"' at position \\\"+e+\\\" in string \\\"+t)}a=s}}var f=o,g=s-a-u;if(0===g)f=o;else if(g>0){var d=T.TEN.pow(g);f=o.divide(d)}else if(g<0){d=T.TEN.pow(-g);f=o.multiply(d)}return r?f.negate():f},T.createNaN=function(){return new T(i.NaN,i.NaN)},T.copy=function(t){return new T(t)},T.magnitude=function(t){var e=Math.abs(t),n=Math.log(e)/Math.log(10),r=Math.trunc(Math.floor(n)),i=Math.pow(10,r);return 10*i<=e&&(r+=1),r},T.stringOfChar=function(t,e){for(var n=new L,r=0;r0){if(o<=0)return O.signum(s);r=i+o}else{if(!(i<0))return O.signum(s);if(o>=0)return O.signum(s);r=-i-o}var a=O.DP_SAFE_EPSILON*r;return s>=a||-s>=a?O.signum(s):2},O.signum=function(t){return t>0?1:t<0?-1:0},O.DP_SAFE_EPSILON=1e-15,e(A.prototype,{setOrdinate:function(t,e,n){},size:function(){},getOrdinate:function(t,e){},getCoordinate:function(){1===arguments.length?arguments[0]: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[s]},getClass:function(){return A}}),A.X=0,A.Y=1,A.Z=2,A.M=3,D.arraycopy=function(t,e,n,r,i){for(var o=0,s=e;s0},interfaces_:function(){return[B]},getClass:function(){return j}}),e(U.prototype,{isInBoundary:function(t){return t>1},interfaces_:function(){return[B]},getClass:function(){return U}}),e(X.prototype,{isInBoundary:function(t){return 1===t},interfaces_:function(){return[B]},getClass:function(){return X}}),B.Mod2BoundaryNodeRule=z,B.EndPointBoundaryNodeRule=j,B.MultiValentEndPointBoundaryNodeRule=U,B.MonoValentEndPointBoundaryNodeRule=X,B.MOD2_BOUNDARY_RULE=new z,B.ENDPOINT_BOUNDARY_RULE=new j,B.MULTIVALENT_ENDPOINT_BOUNDARY_RULE=new U,B.MONOVALENT_ENDPOINT_BOUNDARY_RULE=new X,B.OGC_SFS_BOUNDARY_RULE=B.MOD2_BOUNDARY_RULE,e(Y.prototype,{interfaces_:function(){return[]},getClass:function(){return Y}}),Y.isRing=function(t){return!(t.length<4)&&!!t[0].equals2D(t[t.length-1])},Y.ptNotInList=function(t,e){for(var n=0;n=t?e:[]},Y.indexOf=function(t,e){for(var n=0;n0)&&(e=t[n]);return e},Y.extract=function(t,e,n){e=_.clamp(e,0,t.length),n=_.clamp(n,-1,t.length);var r=n-e+1;n<0&&(r=0),e>=t.length&&(r=0),nr.length)return 1;if(0===n.length)return 0;var i=Y.compare(n,r),o=Y.isEqualReversed(n,r);return o?0:i},OLDcompare:function(t,e){var n=t,r=e;if(n.lengthr.length)return 1;if(0===n.length)return 0;for(var i=Y.increasingDirection(n),o=Y.increasingDirection(r),s=i>0?0:n.length-1,a=o>0?0:n.length-1,u=0;u0))return e.value;e=e.right}}return null},it.prototype.put=function(t,e){if(null===this.root_)return this.root_={key:t,value:e,left:null,right:null,parent:null,color:ts,getValue:function(){return this.value},getKey:function(){return this.key}},this.size_=1,null;var n,r,i=this.root_;do{if(n=i,r=t.compareTo(i.key),r<0)i=i.left;else{if(!(r>0)){var o=i.value;return i.value=e,o}i=i.right}}while(null!==i);var s={key:t,left:null,right:null,value:e,parent:n,color:ts,getValue:function(){return this.value},getKey:function(){return this.key}};return r<0?n.left=s:n.right=s,this.fixAfterInsertion(s),this.size_++,null},it.prototype.fixAfterInsertion=function(t){for(t.color=es;null!=t&&t!=this.root_&&t.parent.color==es;)if(tt(t)==nt(tt(tt(t)))){var e=rt(tt(tt(t)));Q(e)==es?(et(tt(t),ts),et(e,ts),et(tt(tt(t)),es),t=tt(tt(t))):(t==rt(tt(t))&&(t=tt(t),this.rotateLeft(t)),et(tt(t),ts),et(tt(tt(t)),es),this.rotateRight(tt(tt(t))))}else{e=nt(tt(tt(t)));Q(e)==es?(et(tt(t),ts),et(e,ts),et(tt(tt(t)),es),t=tt(tt(t))):(t==nt(tt(t))&&(t=tt(t),this.rotateRight(t)),et(tt(t),ts),et(tt(tt(t)),es),this.rotateLeft(tt(tt(t))))}this.root_.color=ts},it.prototype.values=function(){var t=new w,e=this.getFirstEntry();if(null!==e)for(t.add(e.value);null!==(e=it.successor(e));)t.add(e.value);return t},it.prototype.entrySet=function(){var t=new $,e=this.getFirstEntry();if(null!==e)for(t.add(e);null!==(e=it.successor(e));)t.add(e);return t},it.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}},it.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}},it.prototype.getFirstEntry=function(){var t=this.root_;if(null!=t)for(;null!=t.left;)t=t.left;return t},it.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}e=t.parent;for(var n=t;null!==e&&n===e.right;)n=e,e=e.parent;return e},it.prototype.size=function(){return this.size_},e(ot.prototype,{interfaces_:function(){return[]},getClass:function(){return ot}}),st.prototype=new K,at.prototype=new st,at.prototype.contains=function(t){for(var e=0,n=this.array_.length;e=0;){var s=i.substring(0,o);r.add(s),i=i.substring(o+n),o=i.indexOf(e)}i.length>0&&r.add(i);for(var a=new Array(r.size()).fill(null),u=0;u0)for(var o=i;o0&&r.append(\\\" \\\");for(var o=0;o0&&r.append(\\\",\\\"),r.append(bt.toString(t.getOrdinate(i,o)))}return r.append(\\\")\\\"),r.toString()}},It.ensureValidRing=function(t,e){var n=e.size();if(0===n)return e;if(n<=3)return It.createClosedRing(t,e,4);var r=e.getOrdinate(0,A.X)===e.getOrdinate(n-1,A.X)&&e.getOrdinate(0,A.Y)===e.getOrdinate(n-1,A.Y);return r?e:It.createClosedRing(t,e,n+1)},It.createClosedRing=function(t,e,n){var r=t.create(n,e.getDimension()),i=e.size();It.copy(e,0,r,0,i);for(var o=i;o0&&It.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 ce.computeLength(this.points)},getNumPoints:function(){return this.points.size()},reverse:function(){var t=this.points.copy();It.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,r=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 Pt(this.points.copy(),this.factory)},interfaces_:function(){return[]},getClass:function(){return Pt}}),Pt.MINIMUM_VALID_SIZE=4,Pt.serialVersionUID=-0x3b229e262367a600,c(Rt,ft),e(Rt.prototype,{getSortIndex:function(){return V.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[Ot]},getClass:function(){return Dt}}),e(Ft.prototype,{edit:function(t,e){return t instanceof Pt?e.createLinearRing(this.edit(t.getCoordinateSequence(),t)):t instanceof Nt?e.createLineString(this.edit(t.getCoordinateSequence(),t)):t instanceof St?e.createPoint(this.edit(t.getCoordinateSequence(),t)):t},interfaces_:function(){return[Ot]},getClass:function(){return Ft}}),Tt.NoOpGeometryOperation=At,Tt.CoordinateOperation=Dt,Tt.CoordinateSequenceOperation=Ft,e(kt.prototype,{setOrdinate:function(t,e,n){switch(e){case A.X:this.coordinates[t].x=n;break;case A.Y:this.coordinates[t].y=n;break;case A.Z:this.coordinates[t].z=n;break;default:throw new r(\\\"invalid ordinateIndex\\\")}},size:function(){return this.coordinates.length},getOrdinate:function(t,e){switch(e){case A.X:return this.coordinates[t].x;case A.Y:return this.coordinates[t].y;case A.Z:return this.coordinates[t].z}return i.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 L(17*this.coordinates.length);t.append(\\\"(\\\"),t.append(this.coordinates[0]);for(var e=1;e3&&(r=3),r<2?new kt(n):new kt(n,r)}},interfaces_:function(){return[k,u]},getClass:function(){return Gt}}),Gt.instance=function(){return Gt.instanceObject},Gt.serialVersionUID=-0x38e49fa6cf6f2e00,Gt.instanceObject=new Gt;var rs,is=Object.defineProperty,os=qt({delete:zt,has:Xt,get:jt,set:Yt,keys:Ht,values:Jt,entries:Zt,forEach:Qt,clear:Wt}),ss=\\\"undefined\\\"!=typeof Map&&Map.prototype.values?Map:os;te.prototype=new J,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 w,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 $;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(),r=e.getMaximumSignificantDigits();return new P(n).compareTo(new P(r))},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(i.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,o]},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(re.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(M(arguments[0],A)){var e=arguments[0];return new Nt(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,r=!1,i=t.iterator();i.hasNext();){var o=i.next(),s=o.getClass();null===e&&(e=s),s!==e&&(n=!0),o.isGeometryCollectionOrDerived()&&(r=!0)}if(null===e)return this.createGeometryCollection();if(n||r)return this.createGeometryCollection(re.toGeometryArray(t));var a=t.iterator().next(),u=t.size()>1;if(u){if(a instanceof _t)return this.createMultiPolygon(re.toPolygonArray(t));if(a instanceof Nt)return this.createMultiLineString(re.toLineStringArray(t));if(a instanceof St)return this.createMultiPoint(re.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(M(arguments[0],A)){var e=arguments[0];return new St(e,this)}}},getCoordinateSequenceFactory:function(){return this.coordinateSequenceFactory},createPolygon:function(){if(0===arguments.length)return new _t(null,null,this);if(1===arguments.length){if(M(arguments[0],A)){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 Pt){var n=arguments[0];return this.createPolygon(n,null)}}else if(2===arguments.length){var r=arguments[0],i=arguments[1];return new _t(r,i,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 Tt(this);return e.edit(t,{edit:function(){if(2===arguments.length){var t=arguments[0];return arguments[1],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(M(arguments[0],A)){var e=arguments[0];return new Pt(e,this)}}},createMultiPolygon:function(){if(0===arguments.length)return new Rt(null,this);if(1===arguments.length){var t=arguments[0];return new Rt(t,this)}},createMultiPoint:function(){if(0===arguments.length)return new Lt(null,this);if(1===arguments.length){if(arguments[0]instanceof Array){var t=arguments[0];return new Lt(t,this)}if(arguments[0]instanceof Array){var e=arguments[0];return this.createMultiPoint(null!==e?this.getCoordinateSequenceFactory().create(e):null)}if(M(arguments[0],A)){var n=arguments[0];if(null===n)return this.createMultiPoint(new Array(0).fill(null));for(var r=new Array(n.size()).fill(null),i=0;in?(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;ei?r:i;else{var s=Math.abs(t.x-e.x),a=Math.abs(t.y-e.y);o=r>i?s:a,0!==o||t.equals(e)||(o=Math.max(s,a))}return f.isTrue(!(0===o&&!t.equals(e)),\\\"Bad distance calculation\\\"),o},se.nonRobustComputeEdgeDistance=function(t,e,n){var r=t.x-e.x,i=t.y-e.y,o=Math.sqrt(r*r+i*i);return f.isTrue(!(0===o&&!t.equals(e)),\\\"Invalid distance calculation\\\"),o},se.DONT_INTERSECT=0,se.DO_INTERSECT=1,se.COLLINEAR=2,se.NO_INTERSECTION=0,se.POINT_INTERSECTION=1,se.COLLINEAR_INTERSECTION=2,c(ae,se),e(ae.prototype,{isInSegmentEnvelopes:function(t){var e=new I(this.inputLines[0][0],this.inputLines[0][1]),n=new I(this.inputLines[1][0],this.inputLines[1][1]);return e.contains(t)&&n.contains(t)},computeIntersection:function(){if(3!==arguments.length)return se.prototype.computeIntersection.apply(this,arguments);var t=arguments[0],e=arguments[1],n=arguments[2];return this._isProper=!1,I.intersects(e,n,t)&&0===ce.orientationIndex(e,n,t)&&0===ce.orientationIndex(n,e,t)?(this._isProper=!0,(t.equals(e)||t.equals(n))&&(this._isProper=!1),this.result=se.POINT_INTERSECTION,null):void(this.result=se.NO_INTERSECTION)},normalizeToMinimum:function(t,e,n,r,i){i.x=this.smallestInAbsValue(t.x,e.x,n.x,r.x),i.y=this.smallestInAbsValue(t.y,e.y,n.y,r.y),t.x-=i.x,t.y-=i.y,e.x-=i.x,e.y-=i.y,n.x-=i.x,n.y-=i.y,r.x-=i.x,r.y-=i.y},safeHCoordinateIntersection:function(t,e,n,r){var i=null;try{i=F.intersection(t,e,n,r)}catch(o){if(!(o instanceof C))throw o;i=ae.nearestEndpoint(t,e,n,r)}return i},intersection:function(t,e,n,r){var i=this.intersectionWithNormalization(t,e,n,r);return this.isInSegmentEnvelopes(i)||(i=new g(ae.nearestEndpoint(t,e,n,r))),null!==this.precisionModel&&this.precisionModel.makePrecise(i),i},smallestInAbsValue:function(t,e,n,r){var i=t,o=Math.abs(i);return Math.abs(e)1e-4&&D.out.println(\\\"Distance = \\\"+i.distance(o))},intersectionWithNormalization:function(t,e,n,r){var i=new g(t),o=new g(e),s=new g(n),a=new g(r),u=new g;this.normalizeToEnvCentre(i,o,s,a,u);var l=this.safeHCoordinateIntersection(i,o,s,a);return l.x+=u.x,l.y+=u.y,l},computeCollinearIntersection:function(t,e,n,r){var i=I.intersects(t,e,n),o=I.intersects(t,e,r),s=I.intersects(n,r,t),a=I.intersects(n,r,e);return i&&o?(this.intPt[0]=n,this.intPt[1]=r,se.COLLINEAR_INTERSECTION):s&&a?(this.intPt[0]=t,this.intPt[1]=e,se.COLLINEAR_INTERSECTION):i&&s?(this.intPt[0]=n,this.intPt[1]=t,!n.equals(t)||o||a?se.COLLINEAR_INTERSECTION:se.POINT_INTERSECTION):i&&a?(this.intPt[0]=n,this.intPt[1]=e,!n.equals(e)||o||s?se.COLLINEAR_INTERSECTION:se.POINT_INTERSECTION):o&&s?(this.intPt[0]=r,this.intPt[1]=t,!r.equals(t)||i||a?se.COLLINEAR_INTERSECTION:se.POINT_INTERSECTION):o&&a?(this.intPt[0]=r,this.intPt[1]=e,!r.equals(e)||i||s?se.COLLINEAR_INTERSECTION:se.POINT_INTERSECTION):se.NO_INTERSECTION},normalizeToEnvCentre:function(t,e,n,r,i){var o=t.xe.x?t.x:e.x,u=t.y>e.y?t.y:e.y,l=n.xr.x?n.x:r.x,f=n.y>r.y?n.y:r.y,g=o>l?o:l,d=ac?s:c,v=u0&&o>0||i<0&&o<0)return se.NO_INTERSECTION;var s=ce.orientationIndex(n,r,t),a=ce.orientationIndex(n,r,e);if(s>0&&a>0||s<0&&a<0)return se.NO_INTERSECTION;var u=0===i&&0===o&&0===s&&0===a;return u?this.computeCollinearIntersection(t,e,n,r):(0===i||0===o||0===s||0===a?(this._isProper=!1,t.equals2D(n)||t.equals2D(r)?this.intPt[0]=t:e.equals2D(n)||e.equals2D(r)?this.intPt[0]=e:0===i?this.intPt[0]=new g(n):0===o?this.intPt[0]=new g(r):0===s?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,r)),se.POINT_INTERSECTION)},interfaces_:function(){return[]},getClass:function(){return ae}}),ae.nearestEndpoint=function(t,e,n,r){var i=t,o=ce.distancePointLine(t,n,r),s=ce.distancePointLine(e,n,r);return s0?n>0?-i:i:n>0?i:-i;if(0===e||0===n)return r>0?t>0?i:-i:t>0?-i:i;if(0=r?(t=-t,e=-e,n=-n,r=-r):(i=-i,o=-t,t=-n,n=o,o=-e,e=-r,r=o),0=n))return-i;i=-i,t=-t,n=-n}for(;;){if(1,s=Math.floor(n/t),n-=s*t,r-=s*e,r<0)return-i;if(r>e)return i;if(t>n+n){if(er+r)return-i;n=t-n,r=e-r,i=-i}if(0===r)return 0===n?0:-i;if(0===n)return i;if(s=Math.floor(t/n),t-=s*n,e-=s*r,e<0)return i;if(e>r)return-i;if(n>t+t){if(re+e)return i;t=n-t,e=r-e,i=-i}if(0===e)return 0===t?0:i;if(0===t)return-i}},e(le.prototype,{countSegment:function(t,e){if(t.xr&&(n=e.x,r=t.x),this.p.x>=n&&this.p.x<=r&&(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 i=t.x-this.p.x,o=t.y-this.p.y,s=e.x-this.p.x,a=e.y-this.p.y,u=ue.signOfDet2x2(i,o,s,a);if(0===u)return this.isPointOnSegment=!0,null;a0&&this.crossingCount++}},isPointInPolygon:function(){return this.getLocation()!==S.EXTERIOR},getLocation:function(){return this.isPointOnSegment?S.BOUNDARY:this.crossingCount%2===1?S.INTERIOR:S.EXTERIOR},isOnSegment:function(){return this.isPointOnSegment},interfaces_:function(){return[]},getClass:function(){return le}}),le.locatePointInRing=function(){if(arguments[0]instanceof g&&M(arguments[1],A)){for(var t=arguments[0],e=arguments[1],n=new le(t),r=new g,i=new g,o=1;o1||u<0||u>1)&&(i=!0)}}else i=!0;return i?_.min(ce.distancePointLine(t,n,r),ce.distancePointLine(e,n,r),ce.distancePointLine(n,t,e),ce.distancePointLine(r,t,e)):0},ce.isPointInRing=function(t,e){return ce.locatePointInRing(t,e)!==S.EXTERIOR},ce.computeLength=function(t){var e=t.size();if(e<=1)return 0;var n=0,r=new g;t.getCoordinate(0,r);for(var i=r.x,o=r.y,s=1;sn.y&&(n=s,i=o)}var a=i;do{a-=1,a<0&&(a=e)}while(t[a].equals2D(n)&&a!==i);var u=i;do{u=(u+1)%e}while(t[u].equals2D(n)&&u!==i);var l=t[a],c=t[u];if(l.equals2D(n)||c.equals2D(n)||l.equals2D(c))return!1;var h=ce.computeOrientation(l,n,c);return 0===h?l.x>c.x:h>0},ce.locatePointInRing=function(t,e){return le.locatePointInRing(t,e)},ce.distancePointLinePerpendicular=function(t,e,n){var r=(n.x-e.x)*(n.x-e.x)+(n.y-e.y)*(n.y-e.y),i=((e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y))/r;return Math.abs(i)*Math.sqrt(r)},ce.computeOrientation=function(t,e,n){return ce.orientationIndex(t,e,n)},ce.distancePointLine=function(){if(2===arguments.length){var t=arguments[0],e=arguments[1];if(0===e.length)throw new r(\\\"Line array must contain at least one vertex\\\");for(var n=t.distance(e[0]),i=0;i=1)return s.distance(u);var h=((a.y-s.y)*(u.x-a.x)-(a.x-s.x)*(u.y-a.y))/l;return Math.abs(h)*Math.sqrt(l)}},ce.isOnLine=function(t,e){for(var n=new ae,r=1;r=0&&n>=0?Math.max(e,n):e<=0&&n<=0?Math.max(e,n):0}if(arguments[0]instanceof g){var r=arguments[0];return ce.orientationIndex(this.p0,this.p1,r)}},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 he))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 he){var r=arguments[0],i=this.projectionFactor(r.p0),o=this.projectionFactor(r.p1);if(i>=1&&o>=1)return null;if(i<=0&&o<=0)return null;var s=this.project(r.p0);i<0&&(s=this.p0),i>1&&(s=this.p1);var a=this.project(r.p1);return o<0&&(a=this.p0),o>1&&(a=this.p1),new he(s,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 ce.distancePointLinePerpendicular(t,this.p0,this.p1)},minY:function(){return Math.min(this.p0.y,this.p1.y)},midPoint:function(){return he.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,r=e*e+n*n;if(r<=0)return i.NaN;var o=((t.x-this.p0.x)*e+(t.y-this.p0.y)*n)/r;return o},closestPoints:function(t){var e=this.intersection(t);if(null!==e)return[e,e];var n=new Array(2).fill(null),r=i.MAX_VALUE,o=null,s=this.closestPoint(t.p0);r=s.distance(t.p0),n[0]=s,n[1]=t.p0;var a=this.closestPoint(t.p1);o=a.distance(t.p1),o0&&e<1)return this.project(t);var n=this.p0.distance(t),r=this.p1.distance(t);return n1||i.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 he){var t=arguments[0];return ce.distanceLineLine(this.p0,this.p1,t.p0,t.p1)}if(arguments[0]instanceof g){var e=arguments[0];return ce.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 r=Math.trunc(n)^Math.trunc(n>>32);return e^r},interfaces_:function(){return[o,u]},getClass:function(){return he}}),he.midPoint=function(t,e){return new g((t.x+e.x)/2,(t.y+e.y)/2)},he.serialVersionUID=0x2d2172135f411c00,e(fe.prototype,{isIntersects:function(){return!this.isDisjoint()},isCovers:function(){var t=fe.isTrue(this.matrix[S.INTERIOR][S.INTERIOR])||fe.isTrue(this.matrix[S.INTERIOR][S.BOUNDARY])||fe.isTrue(this.matrix[S.BOUNDARY][S.INTERIOR])||fe.isTrue(this.matrix[S.BOUNDARY][S.BOUNDARY]);return t&&this.matrix[S.EXTERIOR][S.INTERIOR]===lt.FALSE&&this.matrix[S.EXTERIOR][S.BOUNDARY]===lt.FALSE},isCoveredBy:function(){var t=fe.isTrue(this.matrix[S.INTERIOR][S.INTERIOR])||fe.isTrue(this.matrix[S.INTERIOR][S.BOUNDARY])||fe.isTrue(this.matrix[S.BOUNDARY][S.INTERIOR])||fe.isTrue(this.matrix[S.BOUNDARY][S.BOUNDARY]);return t&&this.matrix[S.INTERIOR][S.EXTERIOR]===lt.FALSE&&this.matrix[S.BOUNDARY][S.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[S.INTERIOR][S.INTERIOR])&&this.matrix[S.INTERIOR][S.EXTERIOR]===lt.FALSE&&this.matrix[S.BOUNDARY][S.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[S.INTERIOR][S.INTERIOR]===lt.FALSE&&(fe.isTrue(this.matrix[S.INTERIOR][S.BOUNDARY])||fe.isTrue(this.matrix[S.BOUNDARY][S.INTERIOR])||fe.isTrue(this.matrix[S.BOUNDARY][S.BOUNDARY]))},isOverlaps:function(t,e){return t===lt.P&&e===lt.P||t===lt.A&&e===lt.A?fe.isTrue(this.matrix[S.INTERIOR][S.INTERIOR])&&fe.isTrue(this.matrix[S.INTERIOR][S.EXTERIOR])&&fe.isTrue(this.matrix[S.EXTERIOR][S.INTERIOR]):t===lt.L&&e===lt.L&&1===this.matrix[S.INTERIOR][S.INTERIOR]&&fe.isTrue(this.matrix[S.INTERIOR][S.EXTERIOR])&&fe.isTrue(this.matrix[S.EXTERIOR][S.INTERIOR])},isEquals:function(t,e){return t===e&&fe.isTrue(this.matrix[S.INTERIOR][S.INTERIOR])&&this.matrix[S.INTERIOR][S.EXTERIOR]===lt.FALSE&&this.matrix[S.BOUNDARY][S.EXTERIOR]===lt.FALSE&&this.matrix[S.EXTERIOR][S.INTERIOR]===lt.FALSE&&this.matrix[S.EXTERIOR][S.BOUNDARY]===lt.FALSE},toString:function(){for(var t=new L(\\\"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 r(\\\"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[S.INTERIOR][S.INTERIOR]===lt.FALSE&&this.matrix[S.INTERIOR][S.BOUNDARY]===lt.FALSE&&this.matrix[S.BOUNDARY][S.INTERIOR]===lt.FALSE&&this.matrix[S.BOUNDARY][S.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[S.INTERIOR][S.INTERIOR])&&fe.isTrue(this.matrix[S.INTERIOR][S.EXTERIOR]):t===lt.L&&e===lt.P||t===lt.A&&e===lt.P||t===lt.A&&e===lt.L?fe.isTrue(this.matrix[S.INTERIOR][S.INTERIOR])&&fe.isTrue(this.matrix[S.EXTERIOR][S.INTERIOR]):t===lt.L&&e===lt.L&&0===this.matrix[S.INTERIOR][S.INTERIOR]},interfaces_:function(){return[s]},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],r=arguments[1],i=new fe(n);return i.matches(r)}},fe.isTrue=function(t){return t>=0||t===lt.TRUE};var cs=Object.freeze({Coordinate:g,CoordinateList:b,Envelope:I,LineSegment:he,GeometryFactory:re,Geometry:V,Point:St,LineString:Nt,LinearRing:Pt,Polygon:_t,GeometryCollection:ft,MultiPoint:Lt,MultiLineString:gt,MultiPolygon:Rt,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=ce.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=!ce.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),r=this.toCoordinateArray(n);return this.lineOrPolygon(r)},padArray3:function(t){for(var e=new Array(3).fill(null),n=0;ne[2].y&&(e[2]=t[r]),t[r].x+t[r].y>e[3].x+e[3].y&&(e[3]=t[r]),t[r].x>e[4].x&&(e[4]=t[r]),t[r].x-t[r].y>e[5].x-e[5].y&&(e[5]=t[r]),t[r].y0;)e=n.pop();e=n.push(e),e=n.push(t[r])}return e=n.push(t[0]),n},interfaces_:function(){return[]},getClass:function(){return ye}}),ye.extractCoordinates=function(t){var e=new ve;return t.apply(e),e.getCoordinates()},e(me.prototype,{compare:function(t,e){var n=t,r=e;return me.polarCompare(this.origin,n,r)},interfaces_:function(){return[a]},getClass:function(){return me}}),me.polarCompare=function(t,e,n){var r=e.x-t.x,i=e.y-t.y,o=n.x-t.x,s=n.y-t.y,a=ce.computeOrientation(t,e,n);if(a===ce.COUNTERCLOCKWISE)return 1;if(a===ce.CLOCKWISE)return-1;var u=r*r+i*i,l=o*o+s*s;return ul?1:0},ye.RadialComparator=me,e(xe.prototype,{transformPoint:function(t,e){return this.factory.createPoint(this.transformCoordinates(t.getCoordinateSequence(),t))},transformPolygon:function(t,e){var n=!0,r=this.transformLinearRing(t.getExteriorRing(),t);null!==r&&r instanceof Pt&&!r.isEmpty()||(n=!1);for(var i=new w,o=0;o0&&r<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(),r=0;r=0&&t.add(o+1,new g(i),!1)}},findSegmentIndexToSnap:function(t,e){for(var n=i.MAX_VALUE,r=-1,o=0;oe&&(e=r)}return e}if(2===arguments.length){var i=arguments[0],o=arguments[1];return Math.min(we.computeOverlaySnapTolerance(i),we.computeOverlaySnapTolerance(o))}},we.computeSizeBasedSnapTolerance=function(t){var e=t.getEnvelopeInternal(),n=Math.min(e.getHeight(),e.getWidth()),r=n*we.SNAP_PRECISION_FACTOR;return r},we.snapToSelf=function(t,e,n){var r=new we(t);return r.snapToSelf(e,n)},we.SNAP_PRECISION_FACTOR=1e-9,c(be,xe),e(be.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(),r=this.snapLine(n,this.snapPts);return this.factory.getCoordinateSequenceFactory().create(r)},interfaces_:function(){return[]},getClass:function(){return be}}),e(Ie.prototype,{getCommon:function(){return i.longBitsToDouble(this.commonBits)},add:function(t){var e=i.doubleToLongBits(t);if(this.isFirst)return this.commonBits=e,this.commonSignExp=Ie.signExpBits(this.commonBits),this.isFirst=!1,null;var n=Ie.signExpBits(e);return n!==this.commonSignExp?(this.commonBits=0,null):(this.commonMantissaBitsCount=Ie.numCommonMostSigMantissaBits(this.commonBits,e),void(this.commonBits=Ie.zeroLowerBits(this.commonBits,64-(12+this.commonMantissaBitsCount))))},toString:function(){if(1===arguments.length){var t=arguments[0],e=i.longBitsToDouble(t),n=Long.toBinaryString(t),r=\\\"0000000000000000000000000000000000000000000000000000000000000000\\\"+n,o=r.substring(r.length-64),s=o.substring(0,1)+\\\" \\\"+o.substring(1,12)+\\\"(exp) \\\"+o.substring(12)+\\\" [ \\\"+e+\\\" ]\\\";return s}},interfaces_:function(){return[]},getClass:function(){return Ie}}),Ie.getBit=function(t,e){var n=1<>52},Ie.zeroLowerBits=function(t,e){var n=(1<=0;r--){if(Ie.getBit(t,r)!==Ie.getBit(e,r))return n;n++}return 52},e(Ne.prototype,{addCommonBits:function(t){var e=new Se(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 Se(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 Ne}}),e(Ce.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[q]},getClass:function(){return Ce}}),e(Se.prototype,{filter:function(t,e){var n=t.getOrdinate(e,0)+this.trans.x,r=t.getOrdinate(e,1)+this.trans.y;t.setOrdinate(e,0,n),t.setOrdinate(e,1,r)},isDone:function(){return!1},isGeometryChanged:function(){return!0},interfaces_:function(){return[ht]},getClass:function(){return Se}}),Ne.CommonCoordinateFilter=Ce,Ne.Translater=Se,e(Me.prototype,{next:function(){if(this.atStart)return this.atStart=!1,Me.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 Me(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 Me}}),Me.isAtomic=function(t){return!(t instanceof ft)},e(_e.prototype,{locateInternal:function(){if(arguments[0]instanceof g&&arguments[1]instanceof _t){var t=arguments[0],e=arguments[1];if(e.isEmpty())return S.EXTERIOR;var n=e.getExteriorRing(),r=this.locateInPolygonRing(t,n);if(r===S.EXTERIOR)return S.EXTERIOR;if(r===S.BOUNDARY)return S.BOUNDARY;for(var i=0;i0||this.isIn?S.INTERIOR:S.EXTERIOR)},interfaces_:function(){return[]},getClass:function(){return _e}}),e(Le.prototype,{interfaces_:function(){return[]},getClass:function(){return Le}}),Le.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 r(\\\"Cannot compute the octant for point ( \\\"+t+\\\", \\\"+e+\\\" )\\\");var n=Math.abs(t),i=Math.abs(e);return t>=0?e>=0?n>=i?0:1:n>=i?7:6:e>=0?n>=i?3:2:n>=i?4:5}if(arguments[0]instanceof g&&arguments[1]instanceof g){var o=arguments[0],s=arguments[1],a=s.x-o.x,u=s.y-o.y;if(0===a&&0===u)throw new r(\\\"Cannot compute the octant for two identical points \\\"+o);return Le.octant(a,u)}},e(Pe.prototype,{getCoordinates:function(){},size:function(){},getCoordinate:function(t){},isClosed:function(){},setData:function(t){},getData:function(){},interfaces_:function(){return[]},getClass:function(){return Pe}}),e(Re.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:Le.octant(this.getCoordinate(t),this.getCoordinate(t+1))},setData:function(t){this.data=t},getData:function(){return this.data},toString:function(){return oe.toLineString(new kt(this.pts))},interfaces_:function(){return[Pe]},getClass:function(){return Re}}),e(Te.prototype,{getBounds:function(){},interfaces_:function(){return[]},getClass:function(){return Te}}),e(Oe.prototype,{getItem:function(){return this.item},getBounds:function(){return this.bounds},interfaces_:function(){return[Te,u]},getClass:function(){return Oe}}),e(Ae.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 Ae}}),e(De.prototype,{visitItem:function(t){},interfaces_:function(){return[]},getClass:function(){return De}}),e(Fe.prototype,{insert:function(t,e){},remove:function(t,e){},query:function(){1===arguments.length?arguments[0]:2===arguments.length&&(arguments[0],arguments[1])},interfaces_:function(){return[]},getClass:function(){return Fe}}),e(ke.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[Te,u]},getClass:function(){return ke}}),ke.serialVersionUID=0x5a1e55ec41369800;var hs={reverseOrder:function(){return{compare:function(t,e){return e.compareTo(t)}}},min:function(t){return hs.sort(t),t.get(0)},sort:function(t,e){var n=t.toArray();e?ut.sort(n,e):ut.sort(n);for(var r=t.iterator(),i=0,o=n.length;iGe.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(i)return this.expand(this.boundable2,this.boundable1,t,e),null;throw new r(\\\"neither boundable is composite\\\")},isLeaves:function(){return!(Ge.isComposite(this.boundable1)||Ge.isComposite(this.boundable2))},compareTo:function(t){var e=t;return this._distancee._distance?1:0},expand:function(t,e,n,r){for(var i=t.getChildBoundables(),o=i.iterator();o.hasNext();){var s=o.next(),a=new Ge(s,e,this.itemDistance);a.getDistance()-2),r.getLevel()===n)return i.add(r),null;for(var o=r.getChildBoundables().iterator();o.hasNext();){var s=o.next();s instanceof ke?this.boundablesAtLevel(n,s,i):(f.isTrue(s instanceof Oe),-1===n&&i.add(s))}return null}},query:function(){if(1===arguments.length){var t=arguments[0];this.build();var e=new w;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],r=arguments[1];if(this.build(),this.isEmpty())return null;this.getIntersectsOp().intersects(this.root.getBounds(),n)&&this.query(n,this.root,r)}else if(3===arguments.length)if(M(arguments[2],De)&&arguments[0]instanceof Object&&arguments[1]instanceof ke)for(var i=arguments[0],o=arguments[1],s=arguments[2],a=o.getChildBoundables(),u=0;ue&&(e=i)}}return e+1}},createParentBoundables:function(t,e){f.isTrue(!t.isEmpty());var n=new w;n.add(this.createNode(e));var r=new w(t);hs.sort(r,this.getComparator());for(var i=r.iterator();i.hasNext();){var o=i.next();this.lastNode(n).getChildBoundables().size()===this.getNodeCapacity()&&n.add(this.createNode(e)),this.lastNode(n).addChildBoundable(o)}return n},isEmpty:function(){return this.built?this.root.isEmpty():this.itemBoundables.isEmpty()},interfaces_:function(){return[u]},getClass:function(){return Ve}}),Ve.compareDoubles=function(t,e){return t>e?1:t0);for(var n=new w,r=0;r0;){var h=c.poll(),f=h.getDistance();if(f>=u)break;h.isLeaves()?(u=f,l=h):h.expandToQueue(c,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 Oe(g,d);e=new Ge(this.getRoot(),v,p);return this.nearestNeighbour(e)[0]}},interfaces_:function(){return[Fe,u]},getClass:function(){return ze}}),ze.centreX=function(t){return ze.avg(t.getMinX(),t.getMaxX())},ze.avg=function(t,e){return(t+e)/2},ze.centreY=function(t){return ze.avg(t.getMinY(),t.getMaxY())},c(je,ke),e(je.prototype,{computeBounds:function(){for(var t=null,e=this.getChildBoundables().iterator();e.hasNext();){var n=e.next();null===t?t=new I(n.getBounds()):t.expandToInclude(n.getBounds())}return t},interfaces_:function(){return[]},getClass:function(){return je}}),ze.STRtreeNode=je,ze.serialVersionUID=0x39920f7d5f261e0,ze.xComparator={interfaces_:function(){return[a]},compare:function(t,e){return Ve.compareDoubles(ze.centreX(t.getBounds()),ze.centreX(e.getBounds()))}},ze.yComparator={interfaces_:function(){return[a]},compare:function(t,e){return Ve.compareDoubles(ze.centreY(t.getBounds()),ze.centreY(e.getBounds()))}},ze.intersectsOp={interfaces_:function(){return[IntersectsOp]},intersects:function(t,e){return t.intersects(e)}},ze.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 r=Ue.relativeSign(e.x,n.x),i=Ue.relativeSign(e.y,n.y);switch(t){case 0:return Ue.compareValue(r,i);case 1:return Ue.compareValue(i,r);case 2:return Ue.compareValue(i,-r);case 3:return Ue.compareValue(-r,i);case 4:return Ue.compareValue(-r,-i);case 5:return Ue.compareValue(-i,-r);case 6:return Ue.compareValue(-i,r);case 7:return Ue.compareValue(r,-i)}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[o]},getClass:function(){return Xe}}),e(Ye.prototype,{getSplitCoordinates:function(){var t=new b;this.addEndpoints();for(var e=this.iterator(),n=e.next();e.hasNext();){var r=e.next();this.addEdgeCoordinates(n,r,t),n=r}return t.toCoordinateArray()},addCollapsedNodes:function(){var t=new w;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;ee?t:e;return 0===r&&3===i?3:r},$e.isInHalfPlane=function(t,e){return e===$e.SE?t===$e.SE||t===$e.SW:t===e||t===e+1},$e.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 r(\\\"Cannot compute the quadrant for point ( \\\"+t+\\\", \\\"+e+\\\" )\\\");return t>=0?e>=0?$e.NE:$e.SE:e>=0?$e.NW:$e.SW}if(arguments[0]instanceof g&&arguments[1]instanceof g){var n=arguments[0],i=arguments[1];if(i.x===n.x&&i.y===n.y)throw new r(\\\"Cannot compute the quadrant for two identical points \\\"+n);return i.x>=n.x?i.y>=n.y?$e.NE:$e.SE:i.y>=n.y?$e.NW:$e.SW}},$e.NE=0,$e.NW=1,$e.SW=2,$e.SE=3,e(Qe.prototype,{interfaces_:function(){return[]},getClass:function(){return Qe}}),Qe.getChainStartIndices=function(t){var e=0,n=new w;n.add(new P(e));do{var r=Qe.findChainEnd(t,e);n.add(new P(r)),e=r}while(e=t.length-1)return t.length-1;for(var r=$e.quadrant(t[n],t[n+1]),i=e+1;in.getId()&&(n.computeOverlaps(o,t),this.nOverlaps++),this.segInt.isDone())return null}},interfaces_:function(){return[]},getClass:function(){return nn}}),c(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],r=arguments[3],i=t.getContext(),o=n.getContext();this.si.processIntersections(i,e,o,r)},interfaces_:function(){return[]},getClass:function(){return rn}}),nn.SegmentOverlapAction=rn,c(on,l),e(on.prototype,{getCoordinate:function(){return this.pt},interfaces_:function(){return[]},getClass:function(){return on}}),on.msgWithCoord=function(t,e){return null!==e?t+\\\" [ \\\"+e+\\\" ]\\\":t},e(sn.prototype,{processIntersections:function(t,e,n,r){},isDone:function(){},interfaces_:function(){return[]},getClass:function(){return sn}}),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,r){if(!this.findAllIntersections&&this.hasIntersection())return null;if(t===n&&e===r)return null;if(this.isCheckEndSegmentsOnly){var i=this.isEndSegment(t,e)||this.isEndSegment(n,r);if(!i)return null}var o=t.getCoordinates()[e],s=t.getCoordinates()[e+1],a=n.getCoordinates()[r],u=n.getCoordinates()[r+1];this.li.computeIntersection(o,s,a,u),this.li.hasIntersection()&&this.li.isInteriorIntersection()&&(this.intSegments=new Array(4).fill(null),this.intSegments[0]=o,this.intSegments[1]=s,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[sn]},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 on(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 \\\"+oe.toLineString(t[0],t[1])+\\\" and \\\"+oe.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 w,n=t.iterator();n.hasNext();){var r=n.next();e.add(new Re(r.getCoordinates(),r))}return e},ln.checkValid=function(t){var e=new ln(t);e.checkValid()},e(cn.prototype,{map:function(t){for(var e=new w,n=0;nthis.location.length){var e=new Array(3).fill(null);e[hn.ON]=this.location[hn.ON],e[hn.LEFT]=S.NONE,e[hn.RIGHT]=S.NONE,this.location=e}for(var n=0;n1&&t.append(S.toLocationSymbol(this.location[hn.LEFT])),t.append(S.toLocationSymbol(this.location[hn.ON])),this.location.length>1&&t.append(S.toLocationSymbol(this.location[hn.RIGHT])),t.toString()},setLocations:function(t,e,n){this.location[hn.ON]=t,this.location[hn.LEFT]=e,this.location[hn.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 r=t.getCoordinates();if(e){var i=1;n&&(i=0);for(var o=i;o=0;o--)this.pts.add(r[o])}},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(!ce.isPointInRing(t,e.getCoordinates()))return!1;for(var r=this.holes.iterator();r.hasNext();){var i=r.next();if(i.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],r=e.getLocation(n,hn.RIGHT);if(r===S.NONE)return null;if(this.label.getLocation(n)===S.NONE)return this.label.setLocation(n,r),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 yn}}),c(mn,yn),e(mn.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=S.NONE;if(n=this.label.getLocation(e),!t.isNull(e)){var r=t.getLocation(e);n!==S.BOUNDARY&&(n=r)}return n},setLabel:function(){if(2!==arguments.length)return yn.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 mn){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 r=this.computeMergedLocation(e,n),i=this.label.getLocation(n);i===S.NONE&&this.label.setLocation(n,r)}},add:function(t){this.edges.insert(t),t.setNode(this)},setLabelBoundary:function(t){if(null===this.label)return null;var e=S.NONE;null!==this.label&&(e=this.label.getLocation(t));var n=null;switch(e){case S.BOUNDARY:n=S.INTERIOR;break;case S.INTERIOR:n=S.BOUNDARY;break;default:n=S.BOUNDARY}this.label.setLocation(t,n)},interfaces_:function(){return[]},getClass:function(){return mn}}),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 mn){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 w,n=this.iterator();n.hasNext();){var r=n.next();r.getLabel().getLocation(t)===S.BOUNDARY&&e.add(r)}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){o.linkDirectedEdgesForMinimalEdgeRings();var s=o.buildMinimalRings(),a=this.findShell(s);null!==a?(this.placePolygonHoles(a,s),e.add(a)):n.addAll(s)}else r.add(o)}return r},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 w,n=t.iterator();n.hasNext();){var r=n.next();if(r.isInResult()&&r.getLabel().isArea()&&null===r.getEdgeRing()){var i=new vn(r,this.geometryFactory);e.add(i),i.setInResult()}}return e},placePolygonHoles:function(t,e){for(var n=e.iterator();n.hasNext();){var r=n.next();r.isHole()&&r.setShell(t)}},getPolygons:function(){var t=this.computePolygons(this.shellList);return t},findEdgeRingContaining:function(t,e){for(var n=t.getLinearRing(),r=n.getEnvelopeInternal(),i=n.getCoordinateN(0),o=null,s=null,a=e.iterator();a.hasNext();){var u=a.next(),l=u.getLinearRing(),c=l.getEnvelopeInternal();null!==o&&(s=o.getLinearRing().getEnvelopeInternal());var h=!1;c.contains(r)&&ce.isPointInRing(i,l.getCoordinates())&&(h=!0),h&&(null===o||s.contains(c))&&(o=u)}return o},findShell:function(t){for(var e=0,n=null,r=t.iterator();r.hasNext();){var i=r.next();i.isHole()||(n=i,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];In.linkResultDirectedEdges(n);var r=this.buildMaximalEdgeRings(e),i=new w,o=this.buildMinimalEdgeRings(r,this.shellList,i);this.sortShellsAndHoles(o,this.shellList,i),this.placeFreeHoles(this.shellList,i)}},interfaces_:function(){return[]},getClass:function(){return Nn}}),e(Cn.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 r=t.getLabel(),i=t.getEdge();t.isLineEdge()&&(t.isVisited()||!rr.isResultOfOp(r,e)||i.isCovered()||(n.add(i),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 r=n.next(),i=r.getEdge();if(r.isLineEdge()&&!i.isCoveredSet()){var o=this.op.isCoveredByA(r.getCoordinate());i.setCovered(o)}}},labelIsolatedLines:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),r=n.getLabel();n.isIsolated()&&(r.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(),r=(n.getLabel(),this.geometryFactory.createLineString(n.getCoordinates()));this.resultLineList.add(r),n.setInResult(!0)}},collectBoundaryTouchEdge:function(t,e,n){var r=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(rr.isResultOfOp(r,e)&&e===rr.INTERSECTION&&(n.add(t.getEdge()),t.setVisitedEdge(!0))))},interfaces_:function(){return[]},getClass:function(){return Cn}}),e(Sn.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!==rr.INTERSECTION)){var r=n.getLabel();rr.isResultOfOp(r,t)&&this.filterCoveredNodeToPoint(n)}}},build:function(t){return this.extractNonCoveredResultNodes(t),this.resultPointList},interfaces_:function(){return[]},getClass:function(){return Sn}}),e(Mn.prototype,{locate:function(t){},interfaces_:function(){return[]},getClass:function(){return Mn}}),e(_n.prototype,{locate:function(t){return _n.locate(t,this.geom)},interfaces_:function(){return[Mn]},getClass:function(){return _n}}),_n.isPointInRing=function(t,e){return!!e.getEnvelopeInternal().intersects(t)&&ce.isPointInRing(t,e.getCoordinates())},_n.containsPointInPolygon=function(t,e){if(e.isEmpty())return!1;var n=e.getExteriorRing();if(!_n.isPointInRing(t,n))return!1;for(var r=0;r=0;n--){var r=this.edgeList.get(n),i=r.getSym();null===e&&(e=i),null!==t&&i.setNext(t),t=r}e.setNext(t)},computeDepths:function(){if(1===arguments.length){var t=arguments[0],e=this.findIndex(t),n=(t.getLabel(),t.getDepth(hn.LEFT)),r=t.getDepth(hn.RIGHT),i=this.computeDepths(e+1,this.edgeList.size(),n),o=this.computeDepths(0,e,i);if(o!==r)throw new on(\\\"depth mismatch at \\\"+t.getCoordinate())}else if(3===arguments.length){for(var s=arguments[0],a=arguments[1],u=arguments[2],l=u,c=s;c=0;i--){var o=this.resultAreaEdgeList.get(i),s=o.getSym();switch(null===e&&o.getEdgeRing()===t&&(e=o),r){case this.SCANNING_FOR_INCOMING:if(s.getEdgeRing()!==t)continue;n=s,r=this.LINKING_TO_OUTGOING;break;case this.LINKING_TO_OUTGOING:if(o.getEdgeRing()!==t)continue;n.setNextMin(o),r=this.SCANNING_FOR_INCOMING}}r===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){var r=arguments[0];for(t=0,e=this.iterator();e.hasNext();){n=e.next();n.getEdgeRing()===r&&t++}return t}},getLabel:function(){return this.label},findCoveredLineEdges:function(){for(var t=S.NONE,e=this.iterator();e.hasNext();){var n=e.next(),r=n.getSym();if(!n.isLineEdge()){if(n.isInResult()){t=S.INTERIOR;break}if(r.isInResult()){t=S.EXTERIOR;break}}}if(t===S.NONE)return null;var i=t;for(e=this.iterator();e.hasNext();){n=e.next(),r=n.getSym();n.isLineEdge()?n.getEdge().setCovered(i===S.INTERIOR):(n.isInResult()&&(i=S.EXTERIOR),r.isInResult()&&(i=S.INTERIOR))}},computeLabelling:function(t){Ln.prototype.computeLabelling.call(this,t),this.label=new gn(S.NONE);for(var e=this.iterator();e.hasNext();)for(var n=e.next(),r=n.getEdge(),i=r.getLabel(),o=0;o<2;o++){var s=i.getLocation(o);s!==S.INTERIOR&&s!==S.BOUNDARY||this.label.setLocation(o,S.INTERIOR)}},interfaces_:function(){return[]},getClass:function(){return Pn}}),c(Rn,bn),e(Rn.prototype,{createNode:function(t){return new mn(t,new Pn)},interfaces_:function(){return[]},getClass:function(){return Rn}}),e(Tn.prototype,{computeIntersections:function(t,e){this.mce.computeIntersectsForChain(this.chainIndex,t.mce,t.chainIndex,e)},interfaces_:function(){return[]},getClass:function(){return Tn}}),e(On.prototype,{isDelete:function(){return this.eventType===On.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===On.INSERT},isSameLabel:function(t){return null!==this.label&&this.label===t.label},getDeleteEventIndex:function(){return this.deleteEventIndex},interfaces_:function(){return[o]},getClass:function(){return On}}),On.INSERT=1,On.DELETE=2,e(An.prototype,{interfaces_:function(){return[]},getClass:function(){return An}}),e(Dn.prototype,{isTrivialIntersection:function(t,e,n,r){if(t===n&&1===this.li.getIntersectionNum()){if(Dn.isAdjacentSegments(e,r))return!0;if(t.isClosed()){var i=t.getNumPoints()-1;if(0===e&&r===i||0===r&&e===i)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 r=n.next(),i=r.getCoordinate();if(t.isIntersection(i))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,r){if(t===n&&e===r)return null;this.numTests++;var i=t.getCoordinates()[e],o=t.getCoordinates()[e+1],s=n.getCoordinates()[r],a=n.getCoordinates()[r+1];this.li.computeIntersection(i,o,s,a),this.li.hasIntersection()&&(this.recordIsolated&&(t.setIsolated(!1),n.setIsolated(!1)),this.numIntersections++,this.isTrivialIntersection(t,e,n,r)||(this._hasIntersection=!0,!this.includeProper&&this.li.isProper()||(t.addIntersections(this.li,e,0),n.addIntersections(this.li,r,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 Dn}}),Dn.isAdjacentSegments=function(t,e){return 1===Math.abs(t-e)},c(Fn,An),e(Fn.prototype,{prepareEvents:function(){hs.sort(this.events);for(var t=0;te||this.maxo?1:0},interfaces_:function(){return[a]},getClass:function(){return Gn}}),kn.NodeComparator=Gn,c(Vn,kn),e(Vn.prototype,{query:function(t,e,n){return this.intersects(t,e)?void n.visitItem(this.item):null},interfaces_:function(){return[]},getClass:function(){return Vn}}),c(qn,kn),e(qn.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 qn}}),e(Bn.prototype,{buildTree:function(){hs.sort(this.leaves,new IntervalRTreeNode.NodeComparator);for(var t=this.leaves,e=null,n=new w;;){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 Vn(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){D.out.println(oe.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[o]},getClass:function(){return Wn}}),e(Hn.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 r=e.next(),i=this.createSplitEdge(n,r);t.add(i),n=r}},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,r=this.edge.pts[e.segmentIndex],i=e.dist>0||!e.coord.equals2D(r);i||n--;var o=new Array(n).fill(null),s=0;o[s++]=new g(t.coord);for(var a=t.segmentIndex+1;a<=e.segmentIndex;a++)o[s++]=this.edge.pts[a];return i&&(o[s]=e.coord),new $n(o,new gn(this.edge.label))},add:function(t,e,n){var r=new Wn(t,e,n),i=this.nodeMap.get(r);return null!==i?i:(this.nodeMap.put(r,r),r)},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 Hn}}),e(Jn.prototype,{getChainStartIndices:function(t){var e=0,n=new w;n.add(new P(e));do{var r=this.findChainEnd(t,e);n.add(new P(r)),e=r}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&&(r=1),this.depth[t][n]=r}}},getDelta:function(t){return this.depth[t][hn.RIGHT]-this.depth[t][hn.LEFT]},getLocation:function(t,e){return this.depth[t][e]<=0?S.EXTERIOR:S.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 r=t.getLocation(e,n);r!==S.EXTERIOR&&r!==S.INTERIOR||(this.isNull(e,n)?this.depth[e][n]=Kn.depthAtLocation(r):this.depth[e][n]+=Kn.depthAtLocation(r))}else if(3===arguments.length){var i=arguments[0],o=arguments[1],s=arguments[2];s===S.INTERIOR&&this.depth[i][o]++}},interfaces_:function(){return[]},getClass:function(){return Kn}}),Kn.depthAtLocation=function(t){return t===S.EXTERIOR?0:t===S.INTERIOR?1:Kn.NULL_VALUE},Kn.NULL_VALUE=-1,c($n,yn),e($n.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 $n(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 $n))return!1;var e=t;if(this.pts.length!==e.pts.length)return!1;for(var n=!0,r=!0,i=this.pts.length,o=0;o0?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){$n.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 I;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,r=t.iterator();r.hasNext();){var i=r.next();e[n++]=i.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===S.BOUNDARY&&this.useBoundaryDeterminationRule?this.insertBoundaryPoint(t,e):this.insertPoint(t,e,n))},addPolygonRing:function(t,e,n){if(t.isEmpty())return null;var r=Y.removeRepeatedPoints(t.getCoordinates());if(r.length<4)return this._hasTooFewPoints=!0,this.invalidPoint=r[0],null;var i=e,o=n;ce.isCCW(r)&&(i=n,o=e);var s=new $n(r,new gn(this.argIndex,S.BOUNDARY,i,o));this.lineEdgeMap.put(t,s),this.insertEdge(s),this.insertPoint(this.argIndex,r[0],S.BOUNDARY)},insertPoint:function(t,e,n){var r=this.nodes.addNode(e),i=r.getLabel();null===i?r.label=new gn(t,n):i.setLocation(t,n)},createEdgeSetIntersector:function(){return new Fn},addSelfIntersectionNodes:function(t){for(var e=this.edges.iterator();e.hasNext();)for(var n=e.next(),r=n.getLabel().getLocation(t),i=n.eiList.iterator();i.hasNext();){var o=i.next();this.addSelfIntersectionNode(t,o.coord,r)}},add:function(){if(1!==arguments.length)return In.prototype.add.apply(this,arguments);var t=arguments[0];if(t.isEmpty())return null;if(t instanceof Rt&&(this.useBoundaryDeterminationRule=!1),t instanceof _t)this.addPolygon(t);else if(t instanceof Nt)this.addLineString(t);else if(t instanceof St)this.addPoint(t);else if(t instanceof Lt)this.addCollection(t);else if(t instanceof gt)this.addCollection(t);else if(t instanceof Rt)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 In.prototype.findEdge.apply(this,arguments)},interfaces_:function(){return[]},getClass:function(){return Qn}}),Qn.determineBoundary=function(t,e){return t.isInBoundary(e)?S.BOUNDARY:S.INTERIOR},e(tr.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 tr}}),e(er.prototype,{compareTo:function(t){var e=t,n=er.compareOriented(this.pts,this._orientation,e.pts,e._orientation);return n},interfaces_:function(){return[o]},getClass:function(){return er}}),er.orientation=function(t){return 1===Y.increasingDirection(t)},er.compareOriented=function(t,e,n,r){for(var i=e?1:-1,o=r?1:-1,s=e?t.length:-1,a=r?n.length:-1,u=e?0:t.length-1,l=r?0:n.length-1;;){var c=t[u].compareTo(n[l]);if(0!==c)return c;u+=i,l+=o;var h=u===s,f=l===a;if(h&&!f)return-1;if(!h&&f)return 1;if(h&&f)return 0}},e(nr.prototype,{print:function(t){t.print(\\\"MULTILINESTRING ( \\\");for(var e=0;e0&&t.print(\\\",\\\"),t.print(\\\"(\\\");for(var r=n.getCoordinates(),i=0;i0&&t.print(\\\",\\\"),t.print(r[i].x+\\\" \\\"+r[i].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(){if(arguments[0]instanceof ft){var t=arguments[0];if(t.isEmpty())return t;for(var e=t.getGeometryN(0),n=1;ne.getEnvelopeInternal().getWidth()&&(e=t.getGeometryN(n));return e}if(arguments[0]instanceof V){var r=arguments[0];return r instanceof ft?this.widestGeometry(r):r}},horizontalBisector:function(t){var e=t.getEnvelopeInternal(),n=ar.getBisectorY(t);return this.factory.createLineString([new g(e.getMinX(),n),new g(e.getMaxX(),n)])},add:function(t){if(t instanceof _t)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 hr}}),hr.getSubnodeIndex=function(t,e){var n=-1;return t.min>=e&&(n=1),t.max<=e&&(n=0),n},e(fr.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],r=arguments[1];return n>=this.min&&r<=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 fr}}),gr.exponent=function(t){return dr(64,t)-1023},gr.powerOf2=function(t){return Math.pow(2,t)},e(pr.prototype,{getInterval:function(){return this.interval},getLevel:function(){return this.level},computeKey:function(t){for(this.level=pr.computeLevel(t),this.interval=new fr,this.computeInterval(this.level,t);!this.interval.contains(t);)this.level+=1,this.computeInterval(this.level,t)},computeInterval:function(t,e){var n=gr.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 pr}}),pr.computeLevel=function(t){var e=t.getWidth(),n=gr.exponent(e)+1;return n},c(vr,hr),e(vr.prototype,{getInterval:function(){return this.interval},find:function(t){var e=hr.getSubnodeIndex(t,this.centre);if(-1===e)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=hr.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=hr.getSubnodeIndex(t,this.centre);if(-1!==e){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 r=new fr(e,n),i=new vr(r,this.level-1);return i},interfaces_:function(){return[]},getClass:function(){return vr}}),vr.createNode=function(t){var e=new pr(t),n=new vr(e.getInterval(),e.getLevel());return n},vr.createExpanded=function(t,e){var n=new fr(e);null!==t&&n.expandToInclude(t.interval);var r=vr.createNode(n);return null!==t&&r.insert(t),r},e(yr.prototype,{interfaces_:function(){return[]},getClass:function(){return yr}}),yr.isZeroWidth=function(t,e){var n=e-t;if(0===n)return!0;var r=Math.max(Math.abs(t),Math.abs(e)),i=n/r,o=gr.exponent(i);return o<=yr.MIN_BINARY_EXPONENT},yr.MIN_BINARY_EXPONENT=-50,c(mr,hr),e(mr.prototype,{insert:function(t,e){var n=hr.getSubnodeIndex(t,mr.origin);if(-1===n)return this.add(e),null;var r=this.subnode[n];if(null===r||!r.getInterval().contains(t)){var i=vr.createExpanded(r,t);this.subnode[n]=i}this.insertContained(this.subnode[n],t,e)},isSearchMatch:function(t){return!0},insertContained:function(t,e,n){f.isTrue(t.getInterval().contains(e));var r=yr.isZeroWidth(e.getMin(),e.getMax()),i=null;i=r?t.find(e):t.getNode(e),i.add(n)},interfaces_:function(){return[]},getClass:function(){return mr}}),mr.origin=0,e(xr.prototype,{size:function(){return null!==this.root?this.root.size():0},insert:function(t,e){this.collectStats(t);var n=xr.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 fr(t,t))}if(arguments[0]instanceof fr){var e=arguments[0],n=new w;return this.query(e,n),n}}else if(2===arguments.length){var r=arguments[0],i=arguments[1];this.root.addAllItemsFromOverlapping(r,i)}},iterator:function(){var t=new w;return this.root.addAllItems(t),t.iterator()},remove:function(t,e){var n=xr.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 xr}}),xr.ensureExtent=function(t,e){var n=t.getMin(),r=t.getMax();return n!==r?t:(n===r&&(n-=e/2,r=n+e/2),new fr(n,r))},e(Er.prototype,{isInside:function(t){},interfaces_:function(){return[]},getClass:function(){return Er}}),e(wr.prototype,{testLineSegment:function(t,e){var n=null,r=null,i=null,o=null,s=null,a=e.p0,u=e.p1;r=a.x-t.x,i=a.y-t.y,o=u.x-t.x,s=u.y-t.y,(i>0&&s<=0||s>0&&i<=0)&&(n=ue.signOfDet2x2(r,i,o,s)/(s-i),0Math.PI;)t-=Ir.PI_TIMES_2;for(;t<=-Math.PI;)t+=Ir.PI_TIMES_2;return t},Ir.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],r=n.x-e.x,i=n.y-e.y;return Math.atan2(i,r)}},Ir.isAcute=function(t,e,n){var r=t.x-e.x,i=t.y-e.y,o=n.x-e.x,s=n.y-e.y,a=r*o+i*s;return a>0},Ir.isObtuse=function(t,e,n){var r=t.x-e.x,i=t.y-e.y,o=n.x-e.x,s=n.y-e.y,a=r*o+i*s;return a<0},Ir.interiorAngle=function(t,e,n){var r=Ir.angle(e,t),i=Ir.angle(e,n);return Math.abs(i-r)},Ir.normalizePositive=function(t){if(t<0){for(;t<0;)t+=Ir.PI_TIMES_2;t>=Ir.PI_TIMES_2&&(t=0)}else{for(;t>=Ir.PI_TIMES_2;)t-=Ir.PI_TIMES_2;t<0&&(t=0)}return t},Ir.angleBetween=function(t,e,n){var r=Ir.angle(e,t),i=Ir.angle(e,n);return Ir.diff(r,i)},Ir.diff=function(t,e){var n=null;return n=tMath.PI&&(n=2*Math.PI-n),n},Ir.toRadians=function(t){return t*Math.PI/180},Ir.getTurn=function(t,e){var n=Math.sin(e-t);return n>0?Ir.COUNTERCLOCKWISE:n<0?Ir.CLOCKWISE:Ir.NONE},Ir.angleBetweenOriented=function(t,e,n){var r=Ir.angle(e,t),i=Ir.angle(e,n),o=i-r;return o<=-Math.PI?o+Ir.PI_TIMES_2:o>Math.PI?o-Ir.PI_TIMES_2:o},Ir.PI_TIMES_2=2*Math.PI,Ir.PI_OVER_2=Math.PI/2,Ir.PI_OVER_4=Math.PI/4,Ir.COUNTERCLOCKWISE=ce.COUNTERCLOCKWISE,Ir.CLOCKWISE=ce.CLOCKWISE,Ir.NONE=ce.COLLINEAR,e(Nr.prototype,{area:function(){return Nr.area(this.p0,this.p1,this.p2)},signedArea:function(){return Nr.signedArea(this.p0,this.p1,this.p2)},interpolateZ:function(t){if(null===t)throw new r(\\\"Supplied point is null.\\\");return Nr.interpolateZ(t,this.p0,this.p1,this.p2)},longestSideLength:function(){return Nr.longestSideLength(this.p0,this.p1,this.p2)},isAcute:function(){return Nr.isAcute(this.p0,this.p1,this.p2)},circumcentre:function(){return Nr.circumcentre(this.p0,this.p1,this.p2)},area3D:function(){return Nr.area3D(this.p0,this.p1,this.p2)},centroid:function(){return Nr.centroid(this.p0,this.p1,this.p2)},inCentre:function(){return Nr.inCentre(this.p0,this.p1,this.p2)},interfaces_:function(){return[]},getClass:function(){return Nr}}),Nr.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)},Nr.signedArea=function(t,e,n){return((n.x-t.x)*(e.y-t.y)-(e.x-t.x)*(n.y-t.y))/2},Nr.det=function(t,e,n,r){return t*r-e*n},Nr.interpolateZ=function(t,e,n,r){var i=e.x,o=e.y,s=n.x-i,a=r.x-i,u=n.y-o,l=r.y-o,c=s*l-a*u,h=t.x-i,f=t.y-o,g=(l*h-a*f)/c,d=(-u*h+s*f)/c,p=e.z+g*(n.z-e.z)+d*(r.z-e.z);return p},Nr.longestSideLength=function(t,e,n){var r=t.distance(e),i=e.distance(n),o=n.distance(t),s=r;return i>s&&(s=i),o>s&&(s=o),s},Nr.isAcute=function(t,e,n){return!!Ir.isAcute(t,e,n)&&!!Ir.isAcute(e,n,t)&&!!Ir.isAcute(n,t,e)},Nr.circumcentre=function(t,e,n){var r=n.x,i=n.y,o=t.x-r,s=t.y-i,a=e.x-r,u=e.y-i,l=2*Nr.det(o,s,a,u),c=Nr.det(s,o*o+s*s,u,a*a+u*u),h=Nr.det(o,o*o+s*s,a,a*a+u*u),f=r-c/l,d=i+h/l;return new g(f,d)},Nr.perpendicularBisector=function(t,e){var n=e.x-t.x,r=e.y-t.y,i=new F(t.x+n/2,t.y+r/2,1),o=new F(t.x-r+n/2,t.y+n+r/2,1);return new F(i,o)},Nr.angleBisector=function(t,e,n){var r=e.distance(t),i=e.distance(n),o=r/(r+i),s=n.x-t.x,a=n.y-t.y,u=new g(t.x+o*s,t.y+o*a);return u},Nr.area3D=function(t,e,n){var r=e.x-t.x,i=e.y-t.y,o=e.z-t.z,s=n.x-t.x,a=n.y-t.y,u=n.z-t.z,l=i*u-o*a,c=o*s-r*u,h=r*a-i*s,f=l*l+c*c+h*h,g=Math.sqrt(f)/2;return g},Nr.centroid=function(t,e,n){var r=(t.x+e.x+n.x)/3,i=(t.y+e.y+n.y)/3;return new g(r,i)},Nr.inCentre=function(t,e,n){var r=e.distance(n),i=t.distance(n),o=t.distance(e),s=r+i+o,a=(r*t.x+i*e.x+o*n.x)/s,u=(r*t.y+i*e.y+o*n.y)/s;return new g(a,u)},e(Cr.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),Y.copyDeep(n,0,t,0,n.length-1)),t.length<=2)return this.extremalPts=Y.copyDeep(t),null;for(var r=Cr.lowestPoint(t),i=Cr.pointWitMinAngleWithX(t,r),o=0;o=r;)r=i,o=s,s=Sr.nextIndex(t,o),i=e.distancePerpendicular(t[s]);return rr&&(r=u),us&&(s=l),l=t.length&&(e=0),e},Sr.computeC=function(t,e,n){return t*n.y-e*n.x},Sr.getMinimumDiameter=function(t){return new Sr(t).getDiameter()},Sr.getMinimumRectangle=function(t){return new Sr(t).getMinimumRectangle()},Sr.computeSegmentForLine=function(t,e,n){var r=null,i=null;return Math.abs(e)>Math.abs(t)?(r=new g(0,n/e),i=new g(1,n/e-t/e)):(r=new g(n/t,0),i=new g(n/t-e/t,1)),new he(r,i)};var fs=Object.freeze({Centroid:ge,CGAlgorithms:ce,ConvexHull:ye,InteriorPointArea:sr,InteriorPointLine:ur,InteriorPointPoint:lr,RobustLineIntersector:ae,MCPointInRing:wr,MinimumBoundingCircle:Cr,MinimumDiameter:Sr});e(Mr.prototype,{getResultGeometry:function(){return new _r(this.distanceTolerance).transform(this.inputGeom)},setDistanceTolerance:function(t){if(t<=0)throw new r(\\\"Tolerance must be positive\\\");this.distanceTolerance=t},interfaces_:function(){return[]},getClass:function(){return Mr}}),Mr.densifyPoints=function(t,e,n){for(var r=new he,i=new b,o=0;o1)for(var u=s/a,l=1;ls?1:ot&&(t=n)}return t+1},isEmpty:function(){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 Dr}}),Dr.getSubnodeIndex=function(t,e,n){var r=-1;return t.getMinX()>=e&&(t.getMinY()>=n&&(r=3),t.getMaxY()<=n&&(r=1)),t.getMaxX()<=e&&(t.getMinY()>=n&&(r=2),t.getMaxY()<=n&&(r=0)),r},e(Fr.prototype,{getLevel:function(){return this.level},computeKey:function(){if(1===arguments.length){var t=arguments[0];for(this.level=Fr.computeQuadLevel(t),this.env=new I,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],r=gr.powerOf2(e);this.pt.x=Math.floor(n.getMinX()/r)*r,this.pt.y=Math.floor(n.getMinY()/r)*r,this.env.init(this.pt.x,this.pt.x+r,this.pt.y,this.pt.y+r)}},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 Fr}}),Fr.computeQuadLevel=function(t){var e=t.getWidth(),n=t.getHeight(),r=e>n?e:n,i=gr.exponent(r)+1;return i},c(kr,Dr),e(kr.prototype,{find:function(t){var e=Dr.getSubnodeIndex(t,this.centrex,this.centrey);if(-1===e)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=Dr.getSubnodeIndex(t,this.centrex,this.centrey);if(-1!==e){var n=this.getSubnode(e);return n.getNode(t)}return this},createSubnode:function(t){var e=0,n=0,r=0,i=0;switch(t){case 0:e=this.env.getMinX(),n=this.centrex,r=this.env.getMinY(),i=this.centrey;break;case 1:e=this.centrex,n=this.env.getMaxX(),r=this.env.getMinY(),i=this.centrey;break;case 2:e=this.env.getMinX(),n=this.centrex,r=this.centrey,i=this.env.getMaxY();break;case 3:e=this.centrex,n=this.env.getMaxX(),r=this.centrey,i=this.env.getMaxY()}var o=new I(e,n,r,i),s=new kr(o,this.level-1);return s},insertNode:function(t){f.isTrue(null===this.env||this.env.contains(t.env));var e=Dr.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 kr}}),kr.createNode=function(t){var e=new Fr(t),n=new kr(e.getEnvelope(),e.getLevel());return n},kr.createExpanded=function(t,e){var n=new I(e);null!==t&&n.expandToInclude(t.env);var r=kr.createNode(n);return null!==t&&r.insertNode(t),r},c(Gr,Dr),e(Gr.prototype,{insert:function(t,e){var n=Dr.getSubnodeIndex(t,Gr.origin.x,Gr.origin.y);if(-1===n)return this.add(e),null;var r=this.subnode[n];if(null===r||!r.getEnvelope().contains(t)){var i=kr.createExpanded(r,t);this.subnode[n]=i}this.insertContained(this.subnode[n],t,e)},isSearchMatch:function(t){return!0},insertContained:function(t,e,n){f.isTrue(t.getEnvelope().contains(e));var r=yr.isZeroWidth(e.getMinX(),e.getMaxX()),i=yr.isZeroWidth(e.getMinY(),e.getMaxY()),o=null;o=r||i?t.find(e):t.getNode(e),o.add(n)},interfaces_:function(){return[]},getClass:function(){return Gr}}),Gr.origin=new g(0,0),e(Vr.prototype,{size:function(){return null!==this.root?this.root.size():0},insert:function(t,e){this.collectStats(t);var n=Vr.ensureExtent(t,this.minExtent);this.root.insert(n,e)},query:function(){if(1===arguments.length){var t=arguments[0],e=new jn;return this.query(t,e),e.getItems()}if(2===arguments.length){var n=arguments[0],r=arguments[1];this.root.visit(n,r)}},queryAll:function(){var t=new w;return this.root.addAllItems(t),t},remove:function(t,e){var n=Vr.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 Vr}}),Vr.ensureExtent=function(t,e){var n=t.getMinX(),r=t.getMaxX(),i=t.getMinY(),o=t.getMaxY();return n!==r&&i!==o?t:(n===r&&(n-=e/2,r=n+e/2),i===o&&(i-=e/2,o=i+e/2),new I(n,r,i,o))},Vr.serialVersionUID=-0x678b60c967a25400;var vs=Object.freeze({Quadtree:Vr}),ys=Object.freeze({STRtree:ze}),ms=Object.freeze({quadtree:vs,strtree:ys}),xs=[\\\"Point\\\",\\\"MultiPoint\\\",\\\"LineString\\\",\\\"MultiLineString\\\",\\\"Polygon\\\",\\\"MultiPolygon\\\"];e(qr.prototype,{read:function(t){var e=void 0;e=\\\"string\\\"==typeof t?JSON.parse(t):t;var n=e.type;if(!Es[n])throw new Error(\\\"Unknown GeoJSON type: \\\"+e.type);return-1!==xs.indexOf(n)?Es[n].apply(this,[e.coordinates]):\\\"GeometryCollection\\\"===n?Es[n].apply(this,[e.geometries]):Es[n].apply(this,[e])},write:function(t){var e=t.getGeometryType();if(!ws[e])throw new Error(\\\"Geometry is not supported\\\");return ws[e].apply(this,[t])}});var Es={Feature:function(t){var e={};for(var n in t)e[n]=t[n];if(t.geometry){var r=t.geometry.type;if(!Es[r])throw new Error(\\\"Unknown GeoJSON type: \\\"+t.type);e.geometry=this.read(t.geometry)}return t.bbox&&(e.bbox=Es.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&&r===ce.CLOCKWISE&&(i=!0),i&&(this.minIndex=this.minIndex-1)},getRightmostSideOfSegment:function(t,e){var n=t.getEdge(),r=n.getCoordinates();if(e<0||e+1>=r.length)return-1;if(r[e].y===r[e+1].y)return-1;var i=hn.LEFT;return r[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 r=this.getRightmostSide(this.minDe,this.minIndex);r===hn.LEFT&&(this.orientedDe=this.minDe.getSym())},interfaces_:function(){return[]},getClass:function(){return Zr}}),Kr.prototype.addLast=function(t){this.array_.push(t)},Kr.prototype.removeFirst=function(){return this.array_.shift()},Kr.prototype.isEmpty=function(){return 0===this.array_.length},e($r.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 r=n.next();if(r.isVisited()||r.getSym().isVisited()){e=r;break}}if(null===e)throw new on(\\\"unable to find edge to compute depths at \\\"+t.getCoordinate());t.getEdges().computeDepths(e);for(n=t.getEdges().iterator();n.hasNext();){r=n.next();r.setVisited(!0),this.copySymDepths(r)}},computeDepth:function(t){this.clearVisitedEdges();var e=this.finder.getEdge();e.getNode(),e.getLabel(),e.setEdgeDepths(hn.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(hn.RIGHT)>=1&&e.getDepth(hn.LEFT)<=0&&!e.isInteriorAreaEdge()&&e.setInResult(!0)}},computeDepths:function(t){var e=new $,n=new Kr,r=t.getNode();for(n.addLast(r),e.add(r),t.setVisited(!0);!n.isEmpty();){var i=n.removeFirst();e.add(i),this.computeNodeDepth(i);for(var o=i.getEdges().iterator();o.hasNext();){var s=o.next(),a=s.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 I,e=this.dirEdgeList.iterator();e.hasNext();)for(var n=e.next(),r=n.getEdge().getCoordinates(),i=0;i=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&&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 ti}}),ti.COORDINATE_ARRAY_TYPE=new Array(0).fill(null),e(ei.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=ce.computeOrientation(this.s0,this.s1,this.s2),r=n===ce.CLOCKWISE&&this.side===hn.LEFT||n===ce.COUNTERCLOCKWISE&&this.side===hn.RIGHT;0===n?this.addCollinear(e):r?this.addOutsideTurn(n,e):this.addInsideTurn(n,e)},addLineEndCap:function(t,e){var n=new he(t,e),r=new he;this.computeOffsetSegment(n,hn.LEFT,this.distance,r);var i=new he;this.computeOffsetSegment(n,hn.RIGHT,this.distance,i);var o=e.x-t.x,s=e.y-t.y,a=Math.atan2(s,o);switch(this.bufParams.getEndCapStyle()){case Jr.CAP_ROUND:this.segList.addPt(r.p1),this.addFilletArc(e,a+Math.PI/2,a-Math.PI/2,ce.CLOCKWISE,this.distance),this.segList.addPt(i.p1);break;case Jr.CAP_FLAT:this.segList.addPt(r.p1),this.segList.addPt(i.p1);break;case Jr.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(r.p1.x+u.x,r.p1.y+u.y),c=new g(i.p1.x+u.x,i.p1.y+u.y);this.segList.addPt(l),this.segList.addPt(c)}},getCoordinates:function(){var t=this.segList.getCoordinates();return t},addMitreJoin:function(t,e,n,r){var i=!0,o=null;try{o=F.intersection(e.p0,e.p1,n.p0,n.p1);var s=r<=0?1:o.distance(t)/Math.abs(r);s>this.bufParams.getMitreLimit()&&(i=!1)}catch(t){if(!(t instanceof C))throw t;o=new g(0,0),i=!1}i?this.segList.addPt(o):this.addLimitedMitreJoin(e,n,r,this.bufParams.getMitreLimit())},addFilletCorner:function(t,e,n,r,i){var o=e.x-t.x,s=e.y-t.y,a=Math.atan2(s,o),u=n.x-t.x,l=n.y-t.y,c=Math.atan2(l,u);r===ce.CLOCKWISE?a<=c&&(a+=2*Math.PI):a>=c&&(a-=2*Math.PI),this.segList.addPt(e),this.addFilletArc(t,a,c,r,i),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 r=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(r)}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 ti,this.segList.setPrecisionModel(this.precisionModel),this.segList.setMinimumVertexDistance(t*ei.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()===Jr.JOIN_BEVEL||this.bufParams.getJoinStyle()===Jr.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,ce.CLOCKWISE,this.distance))},closeRing:function(){this.segList.closeRing()},hasNarrowConcaveAngle:function(){return this._hasNarrowConcaveAngle},interfaces_:function(){return[]},getClass:function(){return ei}}),ei.OFFSET_SEGMENT_SEPARATION_FACTOR=.001,ei.INSIDE_TURN_VERTEX_SNAP_DISTANCE_FACTOR=.001,ei.CURVE_VERTEX_SNAP_DISTANCE_FACTOR=1e-6,ei.MAX_CLOSING_SEG_LEN_FACTOR=80,e(ni.prototype,{getOffsetCurve:function(t,e){if(this.distance=e,0===e)return null;var n=e<0,r=Math.abs(e),i=this.getSegGen(r);t.length<=1?this.computePointCurve(t[0],i):this.computeOffsetCurve(t,n,i);var o=i.getCoordinates();return n&&Y.reverse(o),o},computeSingleSidedBufferCurve:function(t,e,n){var r=this.simplifyTolerance(this.distance);if(e){n.addSegments(t,!0);var i=Qr.simplify(t,-r),o=i.length-1;n.initSideSegments(i[o],i[o-1],hn.LEFT),n.addFirstSegment();for(var s=o-2;s>=0;s--)n.addNextSegment(i[s],!0)}else{n.addSegments(t,!1);var a=Qr.simplify(t,r),u=a.length-1;n.initSideSegments(a[0],a[1],hn.LEFT),n.addFirstSegment();for(s=2;s<=u;s++)n.addNextSegment(a[s],!0)}n.addLastSegment(),n.closeRing()},computeRingBufferCurve:function(t,e,n){var r=this.simplifyTolerance(this.distance);e===hn.RIGHT&&(r=-r);var i=Qr.simplify(t,r),o=i.length-1;n.initSideSegments(i[o-1],i[0],e);for(var s=1;s<=o;s++){var a=1!==s;n.addNextSegment(i[s],a)}n.closeRing()},computeLineBufferCurve:function(t,e){var n=this.simplifyTolerance(this.distance),r=Qr.simplify(t,n),i=r.length-1;e.initSideSegments(r[0],r[1],hn.LEFT);for(var o=2;o<=i;o++)e.addNextSegment(r[o],!0);e.addLastSegment(),e.addLineEndCap(r[i-1],r[i]);var s=Qr.simplify(t,-n),a=s.length-1;e.initSideSegments(s[a],s[a-1],hn.LEFT);for(o=a-2;o>=0;o--)e.addNextSegment(s[o],!0);e.addLastSegment(),e.addLineEndCap(s[1],s[0]),e.closeRing()},computePointCurve:function(t,e){switch(this.bufParams.getEndCapStyle()){case Jr.CAP_ROUND:e.createCircle(t);break;case Jr.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),r=this.getSegGen(n);if(t.length<=1)this.computePointCurve(t[0],r);else if(this.bufParams.isSingleSided()){var i=e<0;this.computeSingleSidedBufferCurve(t,i,r)}else this.computeLineBufferCurve(t,r);var o=r.getCoordinates();return o},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 ni.copyCoordinates(t);var r=this.getSegGen(n);return this.computeRingBufferCurve(t,e,r),r.getCoordinates()},computeOffsetCurve:function(t,e,n){var r=this.simplifyTolerance(this.distance);if(e){var i=Qr.simplify(t,-r),o=i.length-1;n.initSideSegments(i[o],i[o-1],hn.LEFT),n.addFirstSegment();for(var s=o-2;s>=0;s--)n.addNextSegment(i[s],!0)}else{var a=Qr.simplify(t,r),u=a.length-1;n.initSideSegments(a[0],a[1],hn.LEFT),n.addFirstSegment();for(s=2;s<=u;s++)n.addNextSegment(a[s],!0)}n.addLastSegment()},getSegGen:function(t){return new ei(this.precisionModel,this.bufParams,t)},interfaces_:function(){return[]},getClass:function(){return ni}}),ni.copyCoordinates=function(t){for(var e=new Array(t.length).fill(null),n=0;ni.getMaxY()||this.findStabbedSegments(t,r.getDirectedEdges(),e)}return e}if(3===arguments.length)if(M(arguments[2],m)&&arguments[0]instanceof g&&arguments[1]instanceof wn){var o=arguments[0],s=arguments[1],a=arguments[2],u=s.getEdge().getCoordinates();for(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||ce.computeOrientation(this.seg.p0,this.seg.p1,o)===ce.RIGHT)){var c=s.getDepth(hn.LEFT);this.seg.p0.equals(u[n])||(c=s.getDepth(hn.RIGHT));var h=new ii(this.seg,c);a.add(h)}}}else if(M(arguments[2],m)&&arguments[0]instanceof g&&M(arguments[1],m)){var f=arguments[0],d=arguments[1],p=arguments[2];for(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=hs.min(e);return n.leftDepth},interfaces_:function(){return[]},getClass:function(){return ri}}),e(ii.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[o]},getClass:function(){return ii}}),ri.DepthSegment=ii,e(oi.prototype,{addPoint:function(t){if(this.distance<=0)return null;var e=t.getCoordinates(),n=this.curveBuilder.getLineCurve(e,this.distance);this.addCurve(n,S.EXTERIOR,S.INTERIOR)},addPolygon:function(t){var e=this.distance,n=hn.LEFT;this.distance<0&&(e=-this.distance,n=hn.RIGHT);var r=t.getExteriorRing(),i=Y.removeRepeatedPoints(r.getCoordinates());if(this.distance<0&&this.isErodedCompletely(r,this.distance))return null;if(this.distance<=0&&i.length<3)return null;this.addPolygonRing(i,e,n,S.EXTERIOR,S.INTERIOR);for(var o=0;o0&&this.isErodedCompletely(s,-this.distance)||this.addPolygonRing(a,e,hn.opposite(n),S.INTERIOR,S.EXTERIOR)}},isTriangleErodedCompletely:function(t,e){var n=new Nr(t[0],t[1],t[2]),r=n.inCentre(),i=ce.distancePointLine(r,n.p0,n.p1);return i=Pt.MINIMUM_VALID_SIZE&&ce.isCCW(t)&&(o=i,s=r,n=hn.opposite(n));var a=this.curveBuilder.getRingCurve(t,n,e);this.addCurve(a,o,s)},add:function(t){if(t.isEmpty())return null;if(t instanceof _t)this.addPolygon(t);else if(t instanceof Nt)this.addLineString(t);else if(t instanceof St)this.addPoint(t);else if(t instanceof Lt)this.addCollection(t);else if(t instanceof gt)this.addCollection(t);else if(t instanceof Rt)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 r=t.getEnvelopeInternal(),i=Math.min(r.getHeight(),r.getWidth());return e<0&&2*Math.abs(e)>i},addCollection:function(t){for(var e=0;er||this.maxyo;if(s)return!1;var a=this.intersectsToleranceSquare(t,e);return f.isTrue(!(s&&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=li.SAFE_ENV_EXPANSION_FACTOR/this.scaleFactor;this.safeEnv=new I(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,r=!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()&&(r=!0),this.li.computeIntersection(t,e,this.corner[3],this.corner[0]),!!this.li.isProper()||!(!n||!r)||!!t.equals(this.pt)||!!e.equals(this.pt))))},addSnappedNode:function(t,e){var n=t.getCoordinate(e),r=t.getCoordinate(e+1);return!!this.intersects(n,r)&&(t.addIntersection(this.getCoordinate(),e),!0)},interfaces_:function(){return[]},getClass:function(){return li}}),li.SAFE_ENV_EXPANSION_FACTOR=.75,e(ci.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],r=arguments[2],i=e.getSafeEnvelope(),o=new hi(e,n,r);return this.index.query(i,{interfaces_:function(){return[De]},visitItem:function(t){var e=t;e.select(i,o)}}),o.isNodeAdded()}},interfaces_:function(){return[]},getClass:function(){return ci}}),c(hi,cr),e(hi.prototype,{isNodeAdded:function(){return this._isNodeAdded},select:function(){if(2!==arguments.length)return cr.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 hi}}),ci.HotPixelSnapAction=hi,e(fi.prototype,{processIntersections:function(t,e,n,r){if(t===n&&e===r)return null;var i=t.getCoordinates()[e],o=t.getCoordinates()[e+1],s=n.getCoordinates()[r],a=n.getCoordinates()[r+1];if(this.li.computeIntersection(i,o,s,a),this.li.hasIntersection()&&this.li.isInteriorIntersection()){for(var u=0;u=0;t--){try{this.bufferReducedPrecision(t)}catch(t){if(!(t instanceof on))throw t;this.saveException=t}if(null!==this.resultGeometry)return null}throw this.saveException}if(1===arguments.length){var e=arguments[0],n=di.precisionScaleFactor(this.argGeom,this.distance,e),r=new ee(n);this.bufferFixedPrecision(r)}},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 ai(this.bufParams);this.resultGeometry=t.buffer(this.argGeom,this.distance)}catch(t){if(!(t instanceof l))throw t;this.saveException=t}},getResultGeometry:function(t){return this.distance=t,this.computeGeometry(),this.resultGeometry},setEndCapStyle:function(t){this.bufParams.setEndCapStyle(t)},interfaces_:function(){return[]},getClass:function(){return di}}),di.bufferOp=function(){if(2===arguments.length){var t=arguments[0],e=arguments[1],n=new di(t),r=n.getResultGeometry(e);return r}if(3===arguments.length){if(Number.isInteger(arguments[2])&&arguments[0]instanceof V&&\\\"number\\\"==typeof arguments[1]){var i=arguments[0],o=arguments[1],s=arguments[2],a=new di(i);a.setQuadrantSegments(s);r=a.getResultGeometry(o);return r}if(arguments[2]instanceof Jr&&arguments[0]instanceof V&&\\\"number\\\"==typeof arguments[1]){var u=arguments[0],l=arguments[1],c=arguments[2];a=new di(u,c),r=a.getResultGeometry(l);return r}}else if(4===arguments.length){var h=arguments[0],f=arguments[1],g=arguments[2],d=arguments[3];a=new di(h);a.setQuadrantSegments(g),a.setEndCapStyle(d);r=a.getResultGeometry(f);return r}},di.precisionScaleFactor=function(t,e,n){var r=t.getEnvelopeInternal(),i=_.max(Math.abs(r.getMaxX()),Math.abs(r.getMaxY()),Math.abs(r.getMinX()),Math.abs(r.getMinY())),o=e>0?e:0,s=i+2*o,a=Math.trunc(Math.log(s)/Math.log(10)+1),u=n-a,l=Math.pow(10,u);return l},di.CAP_ROUND=Jr.CAP_ROUND,di.CAP_BUTT=Jr.CAP_FLAT,di.CAP_FLAT=Jr.CAP_FLAT,di.CAP_SQUARE=Jr.CAP_SQUARE,di.MAX_PRECISION_DIGITS=12;var Ns=Object.freeze({BufferOp:di,BufferParameters:Jr});e(pi.prototype,{filter:function(t){t instanceof _t&&this.comps.add(t)},interfaces_:function(){return[ct]},getClass:function(){return pi}}),pi.getPolygons=function(){if(1===arguments.length){var t=arguments[0];return pi.getPolygons(t,new w)}if(2===arguments.length){var e=arguments[0],n=arguments[1];return e instanceof _t?n.add(e):e instanceof ft&&e.apply(new pi(n)),n}},e(vi.prototype,{isInsideArea:function(){return this.segIndex===vi.INSIDE_AREA},getCoordinate:function(){return this.pt},getGeometryComponent:function(){return this.component},getSegmentIndex:function(){return this.segIndex},interfaces_:function(){return[]},getClass:function(){return vi}}),vi.INSIDE_AREA=-1,e(yi.prototype,{filter:function(t){t instanceof St&&this.pts.add(t)},interfaces_:function(){return[ct]},getClass:function(){return yi}}),yi.getPoints=function(){if(1===arguments.length){var t=arguments[0];return t instanceof St?hs.singletonList(t):yi.getPoints(t,new w)}if(2===arguments.length){var e=arguments[0],n=arguments[1];return e instanceof St?n.add(e):e instanceof ft&&e.apply(new yi(n)),n}},e(mi.prototype,{filter:function(t){(t instanceof St||t instanceof Nt||t instanceof _t)&&this.locations.add(new vi(t,0,t.getCoordinate()))},interfaces_:function(){return[ct]},getClass:function(){return mi}}),mi.getLocations=function(t){var e=new w;return t.apply(new mi(e)),e},e(xi.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],r=1-e,i=pi.getPolygons(this.geom[e]);if(i.size()>0){var o=mi.getLocations(this.geom[r]);if(this.computeContainmentDistance(o,i,n),this.minDistance<=this.terminateDistance)return this.minDistanceLocation[r]=n[0],this.minDistanceLocation[e]=n[1],null}}else if(3===arguments.length)if(arguments[2]instanceof Array&&M(arguments[0],m)&&M(arguments[1],m)){for(var s=arguments[0],a=arguments[1],u=arguments[2],l=0;lthis.minDistance)return null;for(var r=t.getCoordinates(),i=e.getCoordinate(),o=0;othis.minDistance)return null;r=l.getCoordinates();var f=c.getCoordinates();for(o=0;ot&&Y.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 Ei}}),e(wi.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 wi}}),wi.getComponentWithVisitedState=function(t,e){for(;t.hasNext();){var n=t.next();if(n.isVisited()===e)return n}return null},wi.setVisited=function(t,e){for(;t.hasNext();){var n=t.next();n.setVisited(e)}},wi.setMarked=function(t,e){for(;t.hasNext();){var n=t.next();n.setMarked(e)}},c(bi,wi),e(bi.prototype,{isRemoved:function(){return null===this.parentEdge},compareDirection:function(t){return this.quadrant>t.quadrant?1:this.quadrant=t.getNumPoints()&&null===r)return null;var o=t.getCoordinate(i);null!==r&&r.segmentIndex===n.segmentIndex&&(o=r.coord);var s=new En(t,n.coord,o,new gn(t.getLabel()));e.add(s)},createEdgeEndForPrev:function(t,e,n,r){var i=n.segmentIndex;if(0===n.dist){if(0===i)return null;i--}var o=t.getCoordinate(i);null!==r&&r.segmentIndex>=i&&(o=r.coord);var s=new gn(t.getLabel());s.flip();var a=new En(t,n.coord,o,s);e.add(a)},computeEdgeEnds:function(){if(1===arguments.length){for(var t=arguments[0],e=new w,n=t;n.hasNext();){var r=n.next();this.computeEdgeEnds(r,e)}return e}if(2===arguments.length){var i=arguments[0],o=arguments[1],s=i.getEdgeIntersectionList();s.addEndpoints();var a=s.iterator(),u=null,l=null;if(!a.hasNext())return null;var c=a.next();do{u=l,l=c,c=null,a.hasNext()&&(c=a.next()),null!==l&&(this.createEdgeEndForPrev(i,o,l,u),this.createEdgeEndForNext(i,o,l,c))}while(null!==l)}},interfaces_:function(){return[]},getClass:function(){return Di}}),c(Fi,En),e(Fi.prototype,{insert:function(t){this.edgeEnds.add(t)},print:function(t){t.println(\\\"EdgeEndBundle--\\\\x3e 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,r=!1,i=this.iterator();i.hasNext();){var o=i.next(),s=o.getLabel().getLocation(t);s===S.BOUNDARY&&n++,s===S.INTERIOR&&(r=!0)}s=S.NONE;r&&(s=S.INTERIOR),n>0&&(s=Qn.determineBoundary(e,n)),this.label.setLocation(t,s)},computeLabelSide:function(t,e){for(var n=this.iterator();n.hasNext();){var r=n.next();if(r.getLabel().isArea()){var i=r.getLabel().getLocation(t,e);if(i===S.INTERIOR)return this.label.setLocation(t,e,S.INTERIOR),null;i===S.EXTERIOR&&this.label.setLocation(t,e,S.EXTERIOR)}}},getLabel:function(){return this.label},computeLabelSides:function(t){this.computeLabelSide(t,hn.LEFT),this.computeLabelSide(t,hn.RIGHT)},updateIM:function(t){$n.updateIM(this.label,t)},computeLabel:function(t){for(var e=!1,n=this.iterator();n.hasNext();){var r=n.next();r.getLabel().isArea()&&(e=!0)}this.label=e?new gn(S.NONE,S.NONE,S.NONE):new gn(S.NONE);for(var i=0;i<2;i++)this.computeLabelOn(i,t),e&&this.computeLabelSides(i)},interfaces_:function(){return[]},getClass:function(){return Fi}}),c(ki,Ln),e(ki.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 Fi(t),this.insertEdgeEnd(t,e)):e.insert(t)},interfaces_:function(){return[]},getClass:function(){return ki}}),c(Gi,mn),e(Gi.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 Gi}}),c(Vi,bn),e(Vi.prototype,{createNode:function(t){return new Gi(t,new ki)},interfaces_:function(){return[]},getClass:function(){return Vi}}),e(qi.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 r=n.next(),i=this.nodes.addNode(r.getCoordinate());i.setLabel(e,r.getLabel().getLocation(e))}},build:function(t){this.computeIntersectionNodes(t,0),this.copyNodesAndLabels(t,0);var e=new Di,n=e.computeEdgeEnds(t.getEdgeIterator());this.insertEdgeEnds(n)},computeIntersectionNodes:function(t,e){for(var n=t.getEdgeIterator();n.hasNext();)for(var r=n.next(),i=r.getLabel().getLocation(e),o=r.getEdgeIntersectionList().iterator();o.hasNext();){var s=o.next(),a=this.nodes.addNode(s.coord);i===S.BOUNDARY?a.setLabelBoundary(e):a.getLabel().isNull(e)&&a.setLabel(e,S.INTERIOR)}},interfaces_:function(){return[]},getClass:function(){return qi}}),e(Bi.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 r=n.next();if(r.getEdgeEnds().size()>1)return this.invalidPoint=r.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 Bi}}),e(zi.prototype,{buildIndex:function(){this.index=new ze;for(var t=0;t=1&&(e=t.getCoordinateN(0)),this.validErr=new ji(ji.RING_NOT_CLOSED,e)}},checkShellsNotNested:function(t,e){for(var n=0;n=0;r--)n.add(t[r],!1)},Xi.findEdgeRingContaining=function(t,e){for(var n=t.getRing(),r=n.getEnvelopeInternal(),i=n.getCoordinateN(0),o=null,s=null,a=e.iterator();a.hasNext();){var u=a.next(),l=u.getRing(),c=l.getEnvelopeInternal();if(!c.equals(r)&&c.contains(r)){i=Y.ptNotInList(n.getCoordinates(),l.getCoordinates());var h=!1;ce.isPointInRing(i,l.getCoordinates())&&(h=!0),h&&(null===o||s.contains(c))&&(o=u,s=o.getRing().getEnvelopeInternal())}}return o},e(Yi.prototype,{compare:function(t,e){var n=t,r=e;return n.getRing().getEnvelope().compareTo(r.getRing().getEnvelope())},interfaces_:function(){return[a]},getClass:function(){return Yi}}),Xi.EnvelopeComparator=Yi,c(Wi,Li),e(Wi.prototype,{findEdgeRing:function(t){var e=new Xi(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 1===arguments.length&&arguments[0]},computeNextCWEdges:function(){for(var t=this.nodeIterator();t.hasNext();){var e=t.next();Wi.computeNextCWEdges(e)}},addEdge:function(t){if(t.isEmpty())return null;var e=Y.removeRepeatedPoints(t.getCoordinates());if(e.length<2)return null;var n=e[0],r=e[e.length-1],i=this.getNode(n),o=this.getNode(r),s=new Ti(i,o,e[1],!0),a=new Ti(o,i,e[e.length-2],!1),u=new Oi(t);u.setDirectedEdges(s,a),this.add(u)},deleteCutEdges:function(){this.computeNextCWEdges(),Wi.findLabeledEdgeRings(this.dirEdges);for(var t=new w,e=this.dirEdges.iterator();e.hasNext();){var n=e.next();if(!n.isMarked()){var r=n.getSym();if(n.getLabel()===r.getLabel()){n.setMarked(!0),r.setMarked(!0);var i=n.getEdge();t.add(i.getLine())}}}return t},getEdgeRings:function(){this.computeNextCWEdges(),Wi.label(this.dirEdges,-1);var t=Wi.findLabeledEdgeRings(this.dirEdges);this.convertMaximalToMinimalEdgeRings(t);for(var e=new w,n=this.dirEdges.iterator();n.hasNext();){var r=n.next();if(!r.isMarked()&&!r.isInRing()){var i=this.findEdgeRing(r);e.add(i)}}return e},getNode:function(t){var e=this.findNode(t);return null===e&&(e=new Si(t),this.add(e)),e},convertMaximalToMinimalEdgeRings:function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),r=n.getLabel(),i=Wi.findIntersectionNodes(n,r);if(null!==i)for(var o=i.iterator();o.hasNext();){var s=o.next();Wi.computeNextCCWEdges(s,r)}}},deleteDangles:function(){for(var t=this.findNodesOfDegree(1),e=new $,n=new pe,r=t.iterator();r.hasNext();)n.push(r.next());for(;!n.isEmpty();){var i=n.pop();Wi.deleteAllEdges(i);var o=i.getOutEdges().getEdges();for(r=o.iterator();r.hasNext();){var s=r.next();s.setMarked(!0);var a=s.getSym();null!==a&&a.setMarked(!0);var u=s.getEdge();e.add(u.getLine());var l=s.getToNode();1===Wi.getDegreeNonDeleted(l)&&n.push(l)}}return e},interfaces_:function(){return[]},getClass:function(){return Wi}}),Wi.findLabeledEdgeRings=function(t){for(var e=new w,n=1,r=t.iterator();r.hasNext();){var i=r.next();if(!(i.isMarked()||i.getLabel()>=0)){e.add(i);var o=Xi.findDirEdgesInRing(i);Wi.label(o,n),n++}}return e},Wi.getDegreeNonDeleted=function(t){for(var e=t.getOutEdges().getEdges(),n=0,r=e.iterator();r.hasNext();){var i=r.next();i.isMarked()||n++}return n},Wi.deleteAllEdges=function(t){for(var e=t.getOutEdges().getEdges(),n=e.iterator();n.hasNext();){var r=n.next();r.setMarked(!0);var i=r.getSym();null!==i&&i.setMarked(!0)}},Wi.label=function(t,e){for(var n=t.iterator();n.hasNext();){var r=n.next();r.setLabel(e)}},Wi.computeNextCWEdges=function(t){for(var e=t.getOutEdges(),n=null,r=null,i=e.getEdges().iterator();i.hasNext();){var o=i.next();if(!o.isMarked()){if(null===n&&(n=o),null!==r){var s=r.getSym();s.setNext(o)}r=o}}if(null!==r){s=r.getSym();s.setNext(n)}},Wi.computeNextCCWEdges=function(t,e){for(var n=t.getOutEdges(),r=null,i=null,o=n.getEdges(),s=o.size()-1;s>=0;s--){var a=o.get(s),u=a.getSym(),l=null;a.getLabel()===e&&(l=a);var c=null;u.getLabel()===e&&(c=u),null===l&&null===c||(null!==c&&(i=c),null!==l&&(null!==i&&(i.setNext(l),i=null),null===r&&(r=l)))}null!==i&&(f.isTrue(null!==r),i.setNext(r))},Wi.getDegree=function(t,e){for(var n=t.getOutEdges().getEdges(),r=0,i=n.iterator();i.hasNext();){var o=i.next();o.getLabel()===e&&r++}return r},Wi.findIntersectionNodes=function(t,e){var n=t,r=null;do{var i=n.getFromNode();Wi.getDegree(i,e)>1&&(null===r&&(r=new w),r.add(i)),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 r},e(Hi.prototype,{getGeometry:function(){return null===this.geomFactory&&(this.geomFactory=new re),this.polygonize(),this.extractOnlyPolygonal?this.geomFactory.buildGeometry(this.polyList):this.geomFactory.createGeometryCollection(re.toGeometryArray(this.polyList))},getInvalidRingLines:function(){return this.polygonize(),this.invalidRingLines},findValidRings:function(t,e,n){for(var r=t.iterator();r.hasNext();){var i=r.next();i.isValid()?e.add(i):n.add(i.getLineString())}},polygonize:function(){if(null!==this.polyList)return null;if(this.polyList=new w,null===this.graph)return null;this.dangles=this.graph.deleteDangles(),this.cutEdges=this.graph.deleteCutEdges();var t=this.graph.getEdgeRings(),e=new w;this.invalidRingLines=new w,this.isCheckingRingsValid?this.findValidRings(t,e,this.invalidRingLines):e=t,this.findShellsAndHoles(e),Hi.assignHolesToShells(this.holeList,this.shellList),hs.sort(this.shellList,new Xi.EnvelopeComparator);var n=!0;this.extractOnlyPolygonal&&(Hi.findDisjointShells(this.shellList),n=!1),this.polyList=Hi.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(M(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 Nt){var r=arguments[0];this.geomFactory=r.getFactory(),null===this.graph&&(this.graph=new Wi(this.geomFactory)),this.graph.addEdge(r)}else if(arguments[0]instanceof V){var i=arguments[0];i.apply(this.lineStringAdder)}},setCheckRingsValid:function(t){this.isCheckingRingsValid=t},findShellsAndHoles:function(t){this.holeList=new w,this.shellList=new w;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 Hi}}),Hi.findOuterShells=function(t){for(var e=t.iterator();e.hasNext();){var n=e.next(),r=n.getOuterHole();null===r||r.isProcessed()||(n.setIncluded(!0),r.setProcessed(!0))}},Hi.extractPolygons=function(t,e){for(var n=new w,r=t.iterator();r.hasNext();){var i=r.next();(e||i.isIncluded())&&n.add(i.getPolygon())}return n},Hi.assignHolesToShells=function(t,e){for(var n=t.iterator();n.hasNext();){var r=n.next();Hi.assignHoleToShell(r,e)}},Hi.assignHoleToShell=function(t,e){var n=Xi.findEdgeRingContaining(t,e);null!==n&&n.addHole(t)},Hi.findDisjointShells=function(t){Hi.findOuterShells(t);var e=null;do{e=!1;for(var n=t.iterator();n.hasNext();){var r=n.next();r.isIncludedSet()||(r.updateIncluded(),r.isIncludedSet()||(e=!0))}}while(e)},e(Ji.prototype,{filter:function(t){t instanceof Nt&&this.p.add(t)},interfaces_:function(){return[G]},getClass:function(){return Ji}}),Hi.LineStringAdder=Ji;var _s=Object.freeze({Polygonizer:Hi});e(Zi.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(),r=this.arg[1].getGeometry().getDimension(),i=t.hasProperIntersection(),o=t.hasProperInteriorIntersection();2===n&&2===r?i&&e.setAtLeast(\\\"212101212\\\"):2===n&&1===r?(i&&e.setAtLeast(\\\"FFF0FFFF2\\\"),o&&e.setAtLeast(\\\"1FFFFF1FF\\\")):1===n&&2===r?(i&&e.setAtLeast(\\\"F0FFFFFF2\\\"),o&&e.setAtLeast(\\\"1F1FFFFFF\\\")):1===n&&1===r&&o&&e.setAtLeast(\\\"0FFFFFFFF\\\")},labelIsolatedEdges:function(t,e){for(var n=this.arg[t].getEdgeIterator();n.hasNext();){var r=n.next();r.isIsolated()&&(this.labelIsolatedEdge(r,e,this.arg[e].getGeometry()),this.isolatedEdges.add(r))}},labelIsolatedEdge:function(t,e,n){if(n.getDimension()>0){var r=this.ptLocator.locate(t.getCoordinate(),n);t.getLabel().setAllLocations(e,r)}else t.getLabel().setAllLocations(e,S.EXTERIOR)},computeIM:function(){var t=new fe;if(t.set(S.EXTERIOR,S.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 Di,r=n.computeEdgeEnds(this.arg[0].getEdgeIterator());this.insertEdgeEnds(r);var i=n.computeEdgeEnds(this.arg[1].getEdgeIterator());return this.insertEdgeEnds(i),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(),r=this.nodes.addNode(n.getCoordinate());r.setLabel(t,n.getLabel().getLocation(t))}},labelIntersectionNodes:function(t){for(var e=this.arg[t].getEdgeIterator();e.hasNext();)for(var n=e.next(),r=n.getLabel().getLocation(t),i=n.getEdgeIntersectionList().iterator();i.hasNext();){var o=i.next(),s=this.nodes.find(o.coord);s.getLabel().isNull(t)&&(r===S.BOUNDARY?s.setLabelBoundary(t):s.setLabel(t,S.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(),r=n.getLabel().getLocation(t),i=n.getEdgeIntersectionList().iterator();i.hasNext();){var o=i.next(),s=this.nodes.addNode(o.coord);r===S.BOUNDARY?s.setLabelBoundary(t):s.getLabel().isNull(t)&&s.setLabel(t,S.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 r=this.nodes.iterator();r.hasNext();){var i=r.next();i.updateIM(t),i.updateIMFromEdges(t)}},computeDisjointIM:function(t){var e=this.arg[0].getGeometry();e.isEmpty()||(t.set(S.INTERIOR,S.EXTERIOR,e.getDimension()),t.set(S.BOUNDARY,S.EXTERIOR,e.getBoundaryDimension()));var n=this.arg[1].getGeometry();n.isEmpty()||(t.set(S.EXTERIOR,S.INTERIOR,n.getDimension()),t.set(S.EXTERIOR,S.BOUNDARY,n.getBoundaryDimension()))},interfaces_:function(){return[]},getClass:function(){return Zi}}),e(Ki.prototype,{isContainedInBoundary:function(t){if(t instanceof _t)return!1;if(t instanceof St)return this.isPointContainedInBoundary(t);if(t instanceof Nt)return this.isLineStringContainedInBoundary(t);for(var e=0;e0){var r=t;t=e,e=r}var i=!1;return e.y>t.y&&(i=!0),i?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 $i}}),e(Qi.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 eo}}),c(no,Qi),e(no.prototype,{isDone:function(){return!0===this._containsPoint},visit:function(t){if(!(t instanceof _t))return null;var e=t.getEnvelopeInternal();if(!this.rectEnv.intersects(e))return null;for(var n=new g,r=0;r<4;r++)if(this.rectSeq.getCoordinate(r,n),e.contains(n)&&_n.containsPointInPolygon(n,t))return this._containsPoint=!0,null},containsPoint:function(){return this._containsPoint},interfaces_:function(){return[]},getClass:function(){return no}}),c(ro,Qi),e(ro.prototype,{intersects:function(){return this.hasIntersection},isDone:function(){return!0===this.hasIntersection},visit:function(t){var e=t.getEnvelopeInternal();if(!this.rectEnv.intersects(e))return null;var n=zn.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)},uo.union=function(t){var e=new uo(t);return e.union()},uo.STRTREE_NODE_CAPACITY=4,e(lo.prototype,{unionNoOpt:function(t){var e=this.geomFact.createPoint();return or.overlayOp(t,e,rr.UNION)},unionWithNull:function(t,e){return null===t&&null===e?null:null===e?t:null===t?e:t.union(e)},extract:function(){if(M(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 V){var r=arguments[0];null===this.geomFact&&(this.geomFact=r.getFactory()),ao.extract(r,V.SORTINDEX_POLYGON,this.polygons),ao.extract(r,V.SORTINDEX_LINESTRING,this.lines),ao.extract(r,V.SORTINDEX_POINT,this.points)}},union:function(){if(null===this.geomFact)return null;var t=null;if(this.points.size()>0){var e=this.geomFact.buildGeometry(this.points);t=this.unionNoOpt(e)}var n=null;if(this.lines.size()>0){var r=this.geomFact.buildGeometry(this.lines);n=this.unionNoOpt(r)}var i=null;this.polygons.size()>0&&(i=uo.union(this.polygons));var o=this.unionWithNull(n,i),s=null;return s=null===t?o:null===o?t:so.union(t,o),null===s?this.geomFact.createGeometryCollection():s},interfaces_:function(){return[]},getClass:function(){return lo}}),lo.union=function(){if(1===arguments.length){if(M(arguments[0],v)){var t=arguments[0],e=new lo(t);return e.union()}if(arguments[0]instanceof V){var n=arguments[0];e=new lo(n);return e.union()}}else if(2===arguments.length){var r=arguments[0],i=arguments[1];e=new lo(r,i);return e.union()}};var Ps=Object.freeze({UnaryUnionOp:lo}),Rs=Object.freeze({IsValidOp:Ui,ConsistentAreaTester:Bi}),Ts=Object.freeze({BoundaryOp:dt,IsSimpleOp:Wr,buffer:Ns,distance:Cs,linemerge:Ss,overlay:Ms,polygonize:_s,relate:Ls,union:Ps,valid:Rs});c(co,Tt.CoordinateOperation),e(co.prototype,{editCoordinates:function(t,e){if(0===t.length)return null;for(var n=new Array(t.length).fill(null),r=0;r=2&&(r=!0);var i=e.edit(t,new co(this.targetPM,r));return i},changePM:function(t,e){var n=this.createEditor(t.getFactory(),e);return n.edit(t,new Tt.NoOpGeometryOperation)},setRemoveCollapsedComponents:function(t){this.removeCollapsed=t},createFactory:function(t,e){var n=new re(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:M(e,Mt)?e.isValid()?e:this.fixPolygonalTopology(e):e},setPointwise:function(t){this.isPointwise=t},createEditor:function(t,e){if(t.getPrecisionModel()===e)return new Tt;var n=this.createFactory(t,e),r=new Tt(n);return r},interfaces_:function(){return[]},getClass:function(){return ho}}),ho.reduce=function(t,e){var n=new ho(e);return n.reduce(t)},ho.reducePointwise=function(t,e){var n=new ho(e);return n.setPointwise(!0),n.reduce(t)};var Os=Object.freeze({GeometryPrecisionReducer:ho});e(fo.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,r=t,i=t+1;in&&(n=o,r=i)}if(n<=this.distanceTolerance)for(i=t+1;ithis.distanceTolerance&&(o=!1);var l=new he;if(l.p0=this.linePts[t],l.p1=this.linePts[e],r[0]=t,r[1]=e,this.hasBadIntersection(this.line,r,l)&&(o=!1),o){i=this.flatten(t,e);return this.line.addToResult(i),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 r=n.next();if(this.hasInteriorIntersection(r,t))return!0}return!1},findFurthestPoint:function(t,e,n,r){var i=new he;i.p0=t[e],i.p1=t[n];for(var o=-1,s=e,a=e+1;ao&&(o=l,s=a)}return r[0]=o,s},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 r=e;r=e[0]&&ri&&(u=i),o.setMinimumLength(u),o.splitAt(s),o.getSplitPoint()},interfaces_:function(){return[So]},getClass:function(){return Mo}}),Mo.projectedSplitPoint=function(t,e){var n=t.getLineSegment(),r=n.project(e);return r},e(_o.prototype,{interfaces_:function(){return[]},getClass:function(){return _o}}),_o.triArea=function(t,e,n){return(e.x-t.x)*(n.y-t.y)-(e.y-t.y)*(n.x-t.x)},_o.isInCircleDDNormalized=function(t,e,n,r){var i=T.valueOf(t.x).selfSubtract(r.x),o=T.valueOf(t.y).selfSubtract(r.y),s=T.valueOf(e.x).selfSubtract(r.x),a=T.valueOf(e.y).selfSubtract(r.y),u=T.valueOf(n.x).selfSubtract(r.x),l=T.valueOf(n.y).selfSubtract(r.y),c=i.multiply(a).selfSubtract(s.multiply(o)),h=s.multiply(l).selfSubtract(u.multiply(a)),f=u.multiply(o).selfSubtract(i.multiply(l)),g=i.multiply(i).selfAdd(o.multiply(o)),d=s.multiply(s).selfAdd(a.multiply(a)),p=u.multiply(u).selfAdd(l.multiply(l)),v=g.selfMultiply(h).selfAdd(d.selfMultiply(f)).selfAdd(p.selfMultiply(c)),y=v.doubleValue()>0;return y},_o.checkRobustInCircle=function(t,e,n,r){var i=_o.isInCircleNonRobust(t,e,n,r),o=_o.isInCircleDDSlow(t,e,n,r),s=_o.isInCircleCC(t,e,n,r),a=Nr.circumcentre(t,e,n);D.out.println(\\\"p radius diff a = \\\"+Math.abs(r.distance(a)-t.distance(a))/t.distance(a)),i===o&&i===s||(D.out.println(\\\"inCircle robustness failure (double result = \\\"+i+\\\", DD result = \\\"+o+\\\", CC result = \\\"+s+\\\")\\\"),D.out.println(oe.toLineString(new kt([t,e,n,r]))),D.out.println(\\\"Circumcentre = \\\"+oe.toPoint(a)+\\\" radius = \\\"+t.distance(a)),D.out.println(\\\"p radius diff a = \\\"+Math.abs(r.distance(a)/t.distance(a)-1)),D.out.println(\\\"p radius diff b = \\\"+Math.abs(r.distance(a)/e.distance(a)-1)),D.out.println(\\\"p radius diff c = \\\"+Math.abs(r.distance(a)/n.distance(a)-1)),D.out.println())},_o.isInCircleDDFast=function(t,e,n,r){var i=T.sqr(t.x).selfAdd(T.sqr(t.y)).selfMultiply(_o.triAreaDDFast(e,n,r)),o=T.sqr(e.x).selfAdd(T.sqr(e.y)).selfMultiply(_o.triAreaDDFast(t,n,r)),s=T.sqr(n.x).selfAdd(T.sqr(n.y)).selfMultiply(_o.triAreaDDFast(t,e,r)),a=T.sqr(r.x).selfAdd(T.sqr(r.y)).selfMultiply(_o.triAreaDDFast(t,e,n)),u=i.selfSubtract(o).selfAdd(s).selfSubtract(a),l=u.doubleValue()>0;return l},_o.isInCircleCC=function(t,e,n,r){var i=Nr.circumcentre(t,e,n),o=t.distance(i),s=r.distance(i)-o;return s<=0},_o.isInCircleNormalized=function(t,e,n,r){var i=t.x-r.x,o=t.y-r.y,s=e.x-r.x,a=e.y-r.y,u=n.x-r.x,l=n.y-r.y,c=i*a-s*o,h=s*l-u*a,f=u*o-i*l,g=i*i+o*o,d=s*s+a*a,p=u*u+l*l,v=g*h+d*f+p*c;return v>0},_o.isInCircleDDSlow=function(t,e,n,r){var i=T.valueOf(r.x),o=T.valueOf(r.y),s=T.valueOf(t.x),a=T.valueOf(t.y),u=T.valueOf(e.x),l=T.valueOf(e.y),c=T.valueOf(n.x),h=T.valueOf(n.y),f=s.multiply(s).add(a.multiply(a)).multiply(_o.triAreaDDSlow(u,l,c,h,i,o)),g=u.multiply(u).add(l.multiply(l)).multiply(_o.triAreaDDSlow(s,a,c,h,i,o)),d=c.multiply(c).add(h.multiply(h)).multiply(_o.triAreaDDSlow(s,a,u,l,i,o)),p=i.multiply(i).add(o.multiply(o)).multiply(_o.triAreaDDSlow(s,a,u,l,c,h)),v=f.subtract(g).add(d).subtract(p),y=v.doubleValue()>0;return y},_o.isInCircleNonRobust=function(t,e,n,r){var i=(t.x*t.x+t.y*t.y)*_o.triArea(e,n,r)-(e.x*e.x+e.y*e.y)*_o.triArea(t,n,r)+(n.x*n.x+n.y*n.y)*_o.triArea(t,e,r)-(r.x*r.x+r.y*r.y)*_o.triArea(t,e,n)>0;return i},_o.isInCircleRobust=function(t,e,n,r){return _o.isInCircleNormalized(t,e,n,r)},_o.triAreaDDSlow=function(t,e,n,r,i,o){return n.subtract(t).multiply(o.subtract(e)).subtract(r.subtract(e).multiply(i.subtract(t)))},_o.triAreaDDFast=function(t,e,n){var r=T.valueOf(e.x).selfSubtract(t.x).selfMultiply(T.valueOf(n.y).selfSubtract(t.y)),i=T.valueOf(e.y).selfSubtract(t.y).selfMultiply(T.valueOf(n.x).selfSubtract(t.x));return r.selfSubtract(i)},e(Lo.prototype,{circleCenter:function(t,e){var n=new Lo(this.getX(),this.getY()),r=this.bisector(n,t),i=this.bisector(t,e),o=new F(r,i),s=null;try{s=new Lo(o.getX(),o.getY())}catch(r){if(!(r instanceof C))throw r;D.err.println(\\\"a: \\\"+n+\\\" b: \\\"+t+\\\" c: \\\"+e),D.err.println(r)}return s},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(),r=e.getY()-t.getY(),i=new F(t.getX()+n/2,t.getY()+r/2,1),o=new F(t.getX()-r+n/2,t.getY()+n+r/2,1);return new F(i,o)},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 Lo(t*this.p.x,t*this.p.y)},cross:function(){return new Lo(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 Lo(this.p.x-t.getX(),this.p.y-t.getY())},getY:function(){return this.p.y},classify:function(t,e){var n=this,r=e.sub(t),i=n.sub(t),o=r.crossProduct(i);return o>0?Lo.LEFT:o<0?Lo.RIGHT:r.getX()*i.getX()<0||r.getY()*i.getY()<0?Lo.BEHIND:r.magn()n?10*e:10*n,this.frameVertex[0]=new Lo((t.getMaxX()+t.getMinX())/2,t.getMaxY()+r),this.frameVertex[1]=new Lo(t.getMinX()-r,t.getMinY()-r),this.frameVertex[2]=new Lo(t.getMaxX()+r,t.getMinY()-r),this.frameEnv=new I(this.frameVertex[0].getCoordinate(),this.frameVertex[1].getCoordinate()),this.frameEnv.expandToInclude(this.frameVertex[2].getCoordinate())},getTriangleCoordinates:function(t){var e=new Bo;return this.visitTriangles(e,t),e.getTriangles()},getVertices:function(t){for(var e=new $,n=this.quadEdges.iterator();n.hasNext();){var r=n.next(),i=r.orig();!t&&this.isFrameVertex(i)||e.add(i);var o=r.dest();!t&&this.isFrameVertex(o)||e.add(o)}return e},fetchTriangleToVisit:function(t,e,n,r){var i=t,o=0,s=!1;do{this.triEdges[o]=i,this.isFrameEdge(i)&&(s=!0);var a=i.sym();r.contains(a)||e.push(a),r.add(i),o++,i=i.lNext()}while(i!==t);return s&&!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),r=0,i=e.iterator();i.hasNext();){var o=i.next();n[r++]=t.createLineString([o.orig().getCoordinate(),o.dest().getCoordinate()])}return t.createMultiLineString(n)}},getVertexUniqueEdges:function(t){for(var e=new w,n=new $,r=this.quadEdges.iterator();r.hasNext();){var i=r.next(),o=i.orig();n.contains(o)||(n.add(o),!t&&this.isFrameVertex(o)||e.add(i));var s=i.sym(),a=s.orig();n.contains(a)||(n.add(a),!t&&this.isFrameVertex(a)||e.add(s))}return e},getTriangleEdges:function(t){var e=new Vo;return this.visitTriangles(e,t),e.getTriangleEdges()},getPrimaryEdges:function(t){this.visitedKey++;var e=new w,n=new pe;n.push(this.startingEdge);for(var r=new $;!n.empty();){var i=n.pop();if(!r.contains(i)){var o=i.getPrimary();!t&&this.isFrameEdge(o)||e.add(o),n.push(i.oNext()),n.push(i.sym().oNext()),r.add(i),r.add(i.sym())}}return e},delete:function(t){Ro.splice(t,t.oPrev()),Ro.splice(t.sym(),t.sym().oPrev());var e=t.sym(),n=t.rot(),r=t.rot().sym();this.quadEdges.remove(t),this.quadEdges.remove(e),this.quadEdges.remove(n),this.quadEdges.remove(r),t.delete(),e.delete(),n.delete(),r.delete()},locateFromEdge:function(t,e){for(var n=0,r=this.quadEdges.size(),i=e;;){if(n++,n>r)throw new Do(i.toLineSegment());if(t.equals(i.orig())||t.equals(i.dest()))break;if(t.rightOf(i))i=i.sym();else if(t.rightOf(i.oNext())){if(t.rightOf(i.dPrev()))break;i=i.dPrev()}else i=i.oNext()}return i},getTolerance:function(){return this.tolerance},getVoronoiCellPolygons:function(t){this.visitTriangles(new Go,!0);for(var e=new w,n=this.getVertexUniqueEdges(!1),r=n.iterator();r.hasNext();){var i=r.next();e.add(this.getVoronoiCellPolygon(i,t))}return e},getVoronoiDiagram:function(t){var e=this.getVoronoiCellPolygons(t);return t.createGeometryCollection(re.toGeometryArray(e))},getTriangles:function(t){for(var e=this.getTriangleCoordinates(!1),n=new Array(e.size()).fill(null),r=0,i=e.iterator();i.hasNext();){var o=i.next();n[r++]=t.createPolygon(t.createLinearRing(o),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);Ro.splice(n,e);var r=n;do{n=this.connect(e,n.sym()),e=n.oPrev()}while(e.lNext()!==r);return r},locate:function(){if(1===arguments.length){if(arguments[0]instanceof Lo){var t=arguments[0];return this.locator.locate(t)}if(arguments[0]instanceof g){var e=arguments[0];return this.locator.locate(new Lo(e))}}else if(2===arguments.length){var n=arguments[0],r=arguments[1],i=this.locator.locate(new Lo(n));if(null===i)return null;var o=i;i.dest().getCoordinate().equals2D(n)&&(o=i.sym());var s=o;do{if(s.dest().getCoordinate().equals2D(r))return s;s=s.oNext()}while(s!==o);return null}},interfaces_:function(){return[]},getClass:function(){return ko}}),ko.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 r(\\\"Edges do not form a triangle\\\")},e(Go.prototype,{visit:function(t){for(var e=t[0].orig().getCoordinate(),n=t[1].orig().getCoordinate(),r=t[2].orig().getCoordinate(),i=Nr.circumcentre(e,n,r),o=new Lo(i),s=0;s<3;s++)t[s].rot().setOrig(o)},interfaces_:function(){return[Fo]},getClass:function(){return Go}}),e(Vo.prototype,{getTriangleEdges:function(){return this.triList},visit:function(t){this.triList.add(t.clone())},interfaces_:function(){return[Fo]},getClass:function(){return Vo}}),e(qo.prototype,{visit:function(t){this.triList.add([t[0].orig(),t[1].orig(),t[2].orig()])},getTriangleVertices:function(){return this.triList},interfaces_:function(){return[Fo]},getClass:function(){return qo}}),e(Bo.prototype,{checkTriangleSize:function(t){t.length>=2?oe.toLineString(t[0],t[1]):t.length>=1&&oe.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 r=this.coordList.toCoordinateArray();if(4!==r.length)return null;this.triCoords.add(r)}},getTriangles:function(){return this.triCoords},interfaces_:function(){return[Fo]},getClass:function(){return Bo}}),ko.TriangleCircumcentreVisitor=Go,ko.TriangleEdgesListVisitor=Vo,ko.TriangleVertexListVisitor=qo,ko.TriangleCoordinatesVisitor=Bo,ko.EDGE_COINCIDENCE_TOL_FACTOR=1e3,e(zo.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 zo}}),e(jo.prototype,{visit:function(t){},interfaces_:function(){return[]},getClass:function(){return jo}}),e(Uo.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 Uo}}),e(Xo.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 Uo(e,n),this.root;if(this.tolerance>0){var r=this.findBestMatchNode(e);if(null!==r)return r.increment(),r}return this.insertExact(e,n)}},query:function(){var t=arguments,e=this;if(1===arguments.length){var n=arguments[0],r=new w;return this.query(n,r),r}if(2===arguments.length)if(arguments[0]instanceof I&&M(arguments[1],m))!function(){var n=t[0],r=t[1];e.queryNode(e.root,n,!0,{interfaces_:function(){return[jo]},visit:function(t){r.add(t)}})}();else if(arguments[0]instanceof I&&M(arguments[1],jo)){var i=arguments[0],o=arguments[1];this.queryNode(this.root,i,!0,o)}},queryNode:function(t,e,n,r){if(null===t)return null;var i=null,o=null,s=null;n?(i=e.getMinX(),o=e.getMaxX(),s=t.getX()):(i=e.getMinY(),o=e.getMaxY(),s=t.getY());var a=i0&&te)&&xi.isWithinDistance(this,t,e)},distance:function(t){return xi.distance(this,t)},isEquivalentClass:function(t){return this.getClass()===t.getClass()}});var ks=\\\"1.3.0 (6e65adb)\\\";t.version=ks,t.algorithm=fs,t.densify=gs,t.dissolve=ds,t.geom=cs,t.geomgraph=ps,t.index=ms,t.io=bs,t.noding=Is,t.operation=Ts,t.precision=Os,t.simplify=As,t.triangulate=Fs,Object.defineProperty(t,\\\"__esModule\\\",{value:!0})})},\\\"8f76\\\":function(t,e,n){var r=n(\\\"00a2\\\").getCoord,i=n(\\\"feb7\\\").radiansToDistance;t.exports=function(t,e,n){var o=Math.PI/180,s=r(t),a=r(e),u=o*(a[1]-s[1]),l=o*(a[0]-s[0]),c=o*s[1],h=o*a[1],f=Math.pow(Math.sin(u/2),2)+Math.pow(Math.sin(l/2),2)*Math.cos(c)*Math.cos(h);return i(2*Math.atan2(Math.sqrt(f),Math.sqrt(1-f)),n)}},\\\"8ff7\\\":function(t,e,n){\\\"use strict\\\";t.exports=i;var r=n(\\\"ca23\\\");function i(t){var e=r(t),n=e.length;if(n<=2)return[];for(var i=new Array(n),o=e[n-1],s=0;s>1;return[\\\"sum(\\\",d(t.slice(0,e)),\\\",\\\",d(t.slice(e)),\\\")\\\"].join(\\\"\\\")}function p(t){if(2===t.length)return[[\\\"sum(prod(\\\",t[0][0],\\\",\\\",t[1][1],\\\"),prod(-\\\",t[0][1],\\\",\\\",t[1][0],\\\"))\\\"].join(\\\"\\\")];for(var e=[],n=0;n0){if(o<=0)return s;r=i+o}else{if(!(i<0))return s;if(o>=0)return s;r=-(i+o)}var a=l*r;return s>=a||s<=-a?s:y(t,e,n)},function(t,e,n,r){var i=t[0]-r[0],o=e[0]-r[0],s=n[0]-r[0],a=t[1]-r[1],u=e[1]-r[1],l=n[1]-r[1],h=t[2]-r[2],f=e[2]-r[2],g=n[2]-r[2],d=o*l,p=s*u,v=s*a,y=i*l,x=i*u,E=o*a,w=h*(d-p)+f*(v-y)+g*(x-E),b=(Math.abs(d)+Math.abs(p))*Math.abs(h)+(Math.abs(v)+Math.abs(y))*Math.abs(f)+(Math.abs(x)+Math.abs(E))*Math.abs(g),I=c*b;return w>I||-w>I?w:m(t,e,n,r)}];function E(t){var e=x[t.length];return e||(e=x[t.length]=v(t.length)),e.apply(void 0,t)}function w(){while(x.length<=a)x.push(v(x.length));for(var e=[],n=[\\\"slow\\\"],r=0;r<=a;++r)e.push(\\\"a\\\"+r),n.push(\\\"o\\\"+r);var i=[\\\"function getOrientation(\\\",e.join(),\\\"){switch(arguments.length){case 0:case 1:return 0;\\\"];for(r=2;r<=a;++r)i.push(\\\"case \\\",r,\\\":return o\\\",r,\\\"(\\\",e.slice(0,r).join(),\\\");\\\");i.push(\\\"}var s=new Array(arguments.length);for(var i=0;i0?1:-1}),t.exports&&(t.exports=r)},\\\"945f\\\":function(t,e){function n(t,e){if(!t)throw new Error(\\\"No geometry passed\\\");return{type:\\\"Feature\\\",properties:e||{},geometry:t}}t.exports.feature=n,t.exports.point=function(t,e){if(!t)throw new Error(\\\"No coordinates passed\\\");if(void 0===t.length)throw new Error(\\\"Coordinates must be an array\\\");if(t.length<2)throw new Error(\\\"Coordinates must be at least 2 numbers long\\\");if(\\\"number\\\"!==typeof t[0]||\\\"number\\\"!==typeof t[1])throw new Error(\\\"Coordinates must numbers\\\");return n({type:\\\"Point\\\",coordinates:t},e)},t.exports.polygon=function(t,e){if(!t)throw new Error(\\\"No coordinates passed\\\");for(var r=0;r=Math.abs(a)?s>0?t[0]0?t[1]=Math.abs(a)?s>0?t[0]<=n[0]&&n[0]0?t[1]<=n[1]&&n[1]=Math.abs(a)?s>0?t[0]0?t[1]=Math.abs(a)?s>0?t[0]<=n[0]&&n[0]<=e[0]:e[0]<=n[0]&&n[0]<=t[0]:a>0?t[1]<=n[1]&&n[1]<=e[1]:e[1]<=n[1]&&n[1]<=t[1])}t.exports=function(t,e,n){for(var o=r(t),s=r(e),a=0;at&&(e.push(r),n=i)}return e},n.prototype.vector=function(t){var e=this.pos(t+10),n=this.pos(t-10);return{angle:180*Math.atan2(e.y-n.y,e.x-n.x)/3.14,speed:Math.sqrt((n.x-e.x)*(n.x-e.x)+(n.y-e.y)*(n.y-e.y)+(n.z-e.z)*(n.z-e.z))}},n.prototype.pos=function(t){function e(t,e,n,r,i){var o=function(t){var e=t*t,n=e*t;return[n,3*e*(1-t),3*t*(1-t)*(1-t),(1-t)*(1-t)*(1-t)]},s=o(t),a={x:i.x*s[0]+r.x*s[1]+n.x*s[2]+e.x*s[3],y:i.y*s[0]+r.y*s[1]+n.y*s[2]+e.y*s[3],z:i.z*s[0]+r.z*s[1]+n.z*s[2]+e.z*s[3]};return a}var n=t-this.delay;n<0&&(n=0),n>this.duration&&(n=this.duration-1);var r=n/this.duration;if(r>=1)return this.points[this.length-1];var i=Math.floor((this.points.length-1)*r),o=(this.length-1)*r-i;return e(o,this.points[i],this.controls[i][1],this.controls[i+1][0],this.points[i+1])},t.exports=n},\\\"98c6\\\":function(t,e,n){var r=n(\\\"9a15\\\").geometry,i=n(\\\"01a5\\\").geomReduce;t.exports=function(t){return i(t,function(t,e){return t+r(e)},0)}},9935:function(t,e,n){var r=n(\\\"55f9\\\"),i=n(\\\"d31b\\\"),o=n(\\\"716c\\\").geomEach,s=n(\\\"f13f\\\");function a(t,e,n){var r=t.type;if(\\\"Point\\\"===r||\\\"MultiPoint\\\"===r)return t;i(t,!0);var o=t.coordinates;switch(r){case\\\"LineString\\\":t[\\\"coordinates\\\"]=u(o,e,n);break;case\\\"MultiLineString\\\":t[\\\"coordinates\\\"]=o.map(function(t){return u(t,e,n)});break;case\\\"Polygon\\\":t[\\\"coordinates\\\"]=l(o,e,n);break;case\\\"MultiPolygon\\\":t[\\\"coordinates\\\"]=o.map(function(t){return l(t,e,n)})}return t}function u(t,e,n){return r(t.map(function(t){return{x:t[0],y:t[1],z:t[2]}}),e,n).map(function(t){return t.z?[t.x,t.y,t.z]:[t.x,t.y]})}function l(t,e,n){return t.map(function(t){var i=t.map(function(t){return{x:t[0],y:t[1]}});if(i.length<4)throw new Error(\\\"invalid polygon\\\");var o=r(i,e,n).map(function(t){return[t.x,t.y]});while(!c(o))e-=.01*e,o=r(i,e,n).map(function(t){return[t.x,t.y]});return o[o.length-1][0]===o[0][0]&&o[o.length-1][1]===o[0][1]||o.push(o[0]),o})}function c(t){return!(t.length<3)&&!(3===t.length&&t[2][0]===t[0][0]&&t[2][1]===t[0][1])}t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"geojson is required\\\");if(e&&e<0)throw new Error(\\\"invalid tolerance\\\");return!0!==r&&(t=s(t)),o(t,function(t){a(t,e,n)}),t}},\\\"997d\\\":function(t,e){var n=\\\"[object Arguments]\\\"==function(){return Object.prototype.toString.call(arguments)}();function r(t){return\\\"[object Arguments]\\\"==Object.prototype.toString.call(t)}function i(t){return t&&\\\"object\\\"==typeof t&&\\\"number\\\"==typeof t.length&&Object.prototype.hasOwnProperty.call(t,\\\"callee\\\")&&!Object.prototype.propertyIsEnumerable.call(t,\\\"callee\\\")||!1}e=t.exports=n?r:i,e.supported=r,e.unsupported=i},\\\"99ab\\\":function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"aa1a\\\"),o=n(\\\"feb7\\\"),s=n(\\\"8f76\\\"),a=n(\\\"00a2\\\"),u=n(\\\"d592\\\"),l=n(\\\"42a9\\\"),c=o.lineString,h=a.featureOf,f=o.point,g=r.segmentEach,d=o.bearingToAngle,p=o.convertDistance,v=o.degrees2radians;function y(t,e,n,r,o){var a=!0!==o?s(e,t,r):E(e,t,r),l=d(!0!==o?i(e,t):u(e,t)),c=d(!0!==o?i(e,n):u(e,n)),h=Math.abs(l-c);if(h>90)return a;var f=(c+180)%360,g=d(!0!==o?i(n,t):u(n,t)),p=Math.abs(g-f);return p>180&&(p=Math.abs(p-360)),p>90?!0!==o?s(t,n,r):E(t,n,r):!0!==o?a*Math.sin(v(h)):m(e,n,t,r)}function m(t,e,n,r){var i=0;(Math.abs(t[0])>=180||Math.abs(e[0])>=180||Math.abs(n[0])>=180)&&(i=t[0]>0||e[0]>0||n[0]>0?-180:180);var o=f(n),s=w([t[0]+i,t[1]]),a=w([e[0]+i,e[1]]),u=w([n[0]+i,n[1]]),c=b(x(s,a,u));0!==i&&(c[0]-=i);var h=l(o,c,r);return h}function x(t,e,n){var r=t[0],i=t[1],o=e[0],s=e[1],a=n[0],u=n[1],l=o-r,c=s-i,h=l*l+c*c,f=((a-r)*l+(u-i)*c)/h,g=r+f*l,d=i+f*c;return[g,d]}function E(t,e,n){var r=0;Math.abs(t[0])>=180&&(r=t[0]>0?-180:180),Math.abs(e[0])>=180&&(r=e[0]>0?-180:180);var i=w([t[0]+r,t[1]]),o=w([e[0]+r,e[1]]),s=function(t){return t*t},a=s(i[0]-o[0])+s(i[1]-o[1]),u=Math.sqrt(a);return p(u,\\\"meters\\\",n)}function w(t){var e=Math.PI/180,n=6378137,r=20037508.342789244,i=[n*t[0]*e,n*Math.log(Math.tan(.25*Math.PI+.5*t[1]*e))];return i[0]>r&&(i[0]=r),i[0]<-r&&(i[0]=-r),i[1]>r&&(i[1]=r),i[1]<-r&&(i[1]=-r),i}function b(t){var e=180/Math.PI,n=6378137;return[t[0]*e/n,(.5*Math.PI-2*Math.atan(Math.exp(-t[1]/n)))*e]}t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"point is required\\\");if(Array.isArray(t)?t=f(t):h(t,\\\"Point\\\",\\\"point\\\"),!e)throw new Error(\\\"line is required\\\");Array.isArray(e)?e=c(e):h(e,\\\"LineString\\\",\\\"line\\\");var i=1/0,o=t.geometry.coordinates;return g(e,function(t){var e=t.geometry.coordinates[0],s=t.geometry.coordinates[1],a=y(o,e,s,n,r);i>a&&(i=a)}),i}},\\\"9a15\\\":function(t,e,n){var r=n(\\\"64af\\\");function i(t){var e,n=0;switch(t.type){case\\\"Polygon\\\":return o(t.coordinates);case\\\"MultiPolygon\\\":for(e=0;e0){e+=Math.abs(s(t[0]));for(var n=1;n2){for(l=0;l=3&&(n++,r+=6..toRadians()),32==n&&\\\"X\\\"==s&&this.lon<9&&(n--,r-=6..toRadians()),32==n&&\\\"X\\\"==s&&this.lon>=9&&(n++,r+=6..toRadians()),34==n&&\\\"X\\\"==s&&this.lon<21&&(n--,r-=6..toRadians()),34==n&&\\\"X\\\"==s&&this.lon>=21&&(n++,r+=6..toRadians()),36==n&&\\\"X\\\"==s&&this.lon<33&&(n--,r-=6..toRadians()),36==n&&\\\"X\\\"==s&&this.lon>=33&&(n++,r+=6..toRadians());for(var a=this.lat.toRadians(),u=this.lon.toRadians()-r,l=this.datum.ellipsoid.a,c=this.datum.ellipsoid.f,h=.9996,f=Math.sqrt(c*(2-c)),g=c/(2-c),d=g*g,p=g*d,v=g*p,y=g*v,m=g*y,x=Math.cos(u),E=Math.sin(u),w=Math.tan(u),b=Math.tan(a),I=Math.sinh(f*Math.atanh(f*b/Math.sqrt(1+b*b))),N=b*Math.sqrt(1+I*I)-I*Math.sqrt(1+b*b),C=Math.atan2(N,x),S=Math.asinh(E/Math.sqrt(N*N+x*x)),M=l/(1+g)*(1+.25*d+1/64*v+1/256*m),_=[null,.5*g-2/3*d+5/16*p+41/180*v-127/288*y+7891/37800*m,13/48*d-.6*p+557/1440*v+281/630*y-1983433/1935360*m,61/240*p-103/140*v+15061/26880*y+167603/181440*m,49561/161280*v-179/168*y+6601661/7257600*m,34729/80640*y-3418889/1995840*m,.6650675310896665*m],L=C,P=1;P<=6;P++)L+=_[P]*Math.sin(2*P*C)*Math.cosh(2*P*S);var R=S;for(P=1;P<=6;P++)R+=_[P]*Math.cos(2*P*C)*Math.sinh(2*P*S);var T=h*M*R,O=h*M*L,A=1;for(P=1;P<=6;P++)A+=2*P*_[P]*Math.cos(2*P*C)*Math.cosh(2*P*S);var D=0;for(P=1;P<=6;P++)D+=2*P*_[P]*Math.sin(2*P*C)*Math.sinh(2*P*S);var F=Math.atan(N/Math.sqrt(1+N*N)*w),k=Math.atan2(D,A),G=F+k,V=Math.sin(a),q=Math.sqrt(1-f*f*V*V)*Math.sqrt(1+b*b)/Math.sqrt(N*N+x*x),B=M/l*Math.sqrt(A*A+D*D),z=h*q*B;T+=t,O<0&&(O+=e),T=Number(T.toFixed(6)),O=Number(O.toFixed(6));var j=Number(G.toDegrees().toFixed(9)),U=Number(z.toFixed(12)),X=this.lat>=0?\\\"N\\\":\\\"S\\\";return new i(n,X,T,O,this.datum,j,U)},i.prototype.toLatLonE=function(){var t=this.zone,e=this.hemisphere,n=this.easting,i=this.northing;if(isNaN(t)||isNaN(n)||isNaN(i))throw new Error(\\\"Invalid coordinate\\\");var o=5e5,s=1e7,a=this.datum.ellipsoid.a,u=this.datum.ellipsoid.f,l=.9996;n-=o,i=\\\"S\\\"==e?i-s:i;for(var c=Math.sqrt(u*(2-u)),h=u/(2-u),f=h*h,g=h*f,d=h*g,p=h*d,v=h*p,y=a/(1+h)*(1+.25*f+1/64*d+1/256*v),m=n/(l*y),x=i/(l*y),E=[null,.5*h-2/3*f+37/96*g-1/360*d-81/512*p+96199/604800*v,1/48*f+1/15*g-437/1440*d+46/105*p-1118711/3870720*v,17/480*g-37/840*d-209/4480*p+5569/90720*v,4397/161280*d-11/504*p-830251/7257600*v,4583/161280*p-108847/3991680*v,.03233083094085698*v],w=x,b=1;b<=6;b++)w-=E[b]*Math.sin(2*b*x)*Math.cosh(2*b*m);var I=m;for(b=1;b<=6;b++)I-=E[b]*Math.cos(2*b*x)*Math.sinh(2*b*m);var N=Math.sinh(I),C=Math.sin(w),S=Math.cos(w),M=C/Math.sqrt(N*N+S*S),_=M;do{var L=Math.sinh(c*Math.atanh(c*_/Math.sqrt(1+_*_))),P=_*Math.sqrt(1+L*L)-L*Math.sqrt(1+_*_),R=(M-P)/Math.sqrt(1+P*P)*(1+(1-c*c)*_*_)/((1-c*c)*Math.sqrt(1+_*_));_+=R}while(Math.abs(R)>1e-12);var T=_,O=Math.atan(T),A=Math.atan2(N,S),D=1;for(b=1;b<=6;b++)D-=2*b*E[b]*Math.cos(2*b*x)*Math.cosh(2*b*m);var F=0;for(b=1;b<=6;b++)F+=2*b*E[b]*Math.sin(2*b*x)*Math.sinh(2*b*m);var k=Math.atan(Math.tan(w)*Math.tanh(I)),G=Math.atan2(F,D),V=k+G,q=Math.sin(O),B=Math.sqrt(1-c*c*q*q)*Math.sqrt(1+T*T)*Math.sqrt(N*N+S*S),z=y/a/Math.sqrt(D*D+F*F),j=l*B*z,U=(6*(t-1)-180+3).toRadians();A+=U;var X=Number(O.toDegrees().toFixed(11)),Y=Number(A.toDegrees().toFixed(11)),W=Number(V.toDegrees().toFixed(9)),H=Number(j.toFixed(12)),J=new r(X,Y,this.datum);return J.convergence=W,J.scale=H,J},i.parse=function(t,e){if(void 0===e&&(e=r.datum.WGS84),t=t.trim().match(/\\\\S+/g),null==t||4!=t.length)throw new Error(\\\"Invalid UTM coordinate ‘\\\"+t+\\\"’\\\");var n=t[0],o=t[1],s=t[2],a=t[3];return new i(n,o,s,a,e)},i.prototype.toString=function(t){t=Number(t||0);var e=this.zone<10?\\\"0\\\"+this.zone:this.zone,n=this.hemisphere,r=this.easting,i=this.northing;return isNaN(e)||!n.match(/[NS]/)||isNaN(r)||isNaN(i)?\\\"\\\":e+\\\" \\\"+n+\\\" \\\"+r.toFixed(t)+\\\" \\\"+i.toFixed(t)},void 0===Math.sinh&&(Math.sinh=function(t){return(Math.exp(t)-Math.exp(-t))/2}),void 0===Math.cosh&&(Math.cosh=function(t){return(Math.exp(t)+Math.exp(-t))/2}),void 0===Math.tanh&&(Math.tanh=function(t){return(Math.exp(t)-Math.exp(-t))/(Math.exp(t)+Math.exp(-t))}),void 0===Math.asinh&&(Math.asinh=function(t){return Math.log(t+Math.sqrt(1+t*t))}),void 0===Math.atanh&&(Math.atanh=function(t){return Math.log((1+t)/(1-t))/2}),t.exports&&(t.exports=i)},\\\"9def\\\":function(t,e,n){var r=n(\\\"4588\\\"),i=Math.min;t.exports=function(t){return t>0?i(r(t),9007199254740991):0}},\\\"9e09\\\":function(t,e,n){var r=n(\\\"716c\\\").coordEach,i=n(\\\"1a3f\\\"),o=n(\\\"feb7\\\").polygon;t.exports=function(t){var e=[];r(t,function(t){e.push([t[0],t[1]])});var n=i(e);if(n.length>=3){for(var s=[],a=0;a0?1:t<0?-1:0},C=Math.sqrt,S=Math.tan;function M(t){return t>1?0:t<-1?l:Math.acos(t)}function _(t){return t>1?c:t<-1?-c:Math.asin(t)}function L(t){return(t=I(t/2))*t}function P(){}function R(t,e){t&&O.hasOwnProperty(t.type)&&O[t.type](t,e)}var T={Feature:function(t,e){R(t.geometry,e)},FeatureCollection:function(t,e){var n=t.features,r=-1,i=n.length;while(++r=0?1:-1,i=r*n,o=m(e),s=I(e),a=q*s,u=V*o+a*m(i),l=a*r*I(i);z.add(y(l,u)),G=t,V=o,q=s}var J=function(t){return j.reset(),B(t,U),2*j};function Z(t){return[y(t[1],t[0]),_(t[2])]}function K(t){var e=t[0],n=t[1],r=m(n);return[r*m(e),r*I(e),I(n)]}function $(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function Q(t,e){return[t[1]*e[2]-t[2]*e[1],t[2]*e[0]-t[0]*e[2],t[0]*e[1]-t[1]*e[0]]}function tt(t,e){t[0]+=e[0],t[1]+=e[1],t[2]+=e[2]}function et(t,e){return[t[0]*e,t[1]*e,t[2]*e]}function nt(t){var e=C(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=e,t[1]/=e,t[2]/=e}var rt,it,ot,st,at,ut,lt,ct,ht,ft,gt=r(),dt={point:pt,lineStart:yt,lineEnd:mt,polygonStart:function(){dt.point=xt,dt.lineStart=Et,dt.lineEnd=wt,gt.reset(),U.polygonStart()},polygonEnd:function(){U.polygonEnd(),dt.point=pt,dt.lineStart=yt,dt.lineEnd=mt,z<0?(rt=-(ot=180),it=-(st=90)):gt>a?st=90:gt<-a&&(it=-90),ft[0]=rt,ft[1]=ot}};function pt(t,e){ht.push(ft=[rt=t,ot=t]),est&&(st=e)}function vt(t,e){var n=K([t*d,e*d]);if(ct){var r=Q(ct,n),i=[r[1],-r[0],0],o=Q(i,r);nt(o),o=Z(o);var s,a=t-at,u=a>0?1:-1,l=o[0]*g*u,c=p(a)>180;c^(u*atst&&(st=s)):(l=(l+360)%360-180,c^(u*atst&&(st=e))),c?tbt(rt,ot)&&(ot=t):bt(t,ot)>bt(rt,ot)&&(rt=t):ot>=rt?(tot&&(ot=t)):t>at?bt(rt,t)>bt(rt,ot)&&(ot=t):bt(t,ot)>bt(rt,ot)&&(rt=t)}else ht.push(ft=[rt=t,ot=t]);est&&(st=e),ct=n,at=t}function yt(){dt.point=vt}function mt(){ft[0]=rt,ft[1]=ot,dt.point=pt,ct=null}function xt(t,e){if(ct){var n=t-at;gt.add(p(n)>180?n+(n>0?360:-360):n)}else ut=t,lt=e;U.point(t,e),vt(t,e)}function Et(){U.lineStart()}function wt(){xt(ut,lt),U.lineEnd(),p(gt)>a&&(rt=-(ot=180)),ft[0]=rt,ft[1]=ot,ct=null}function bt(t,e){return(e-=t)<0?e+360:e}function It(t,e){return t[0]-e[0]}function Nt(t,e){return t[0]<=t[1]?t[0]<=e&&e<=t[1]:ebt(r[0],r[1])&&(r[1]=i[1]),bt(i[0],r[1])>bt(r[0],r[1])&&(r[0]=i[0])):o.push(r=i);for(s=-1/0,n=o.length-1,e=0,r=o[n];e<=n;r=i,++e)i=o[e],(a=bt(r[1],i[0]))>s&&(s=a,rt=i[0],ot=r[1])}return ht=ft=null,rt===1/0||it===1/0?[[NaN,NaN],[NaN,NaN]]:[[rt,it],[ot,st]]},zt={sphere:P,point:jt,lineStart:Xt,lineEnd:Ht,polygonStart:function(){zt.lineStart=Jt,zt.lineEnd=Zt},polygonEnd:function(){zt.lineStart=Xt,zt.lineEnd=Ht}};function jt(t,e){t*=d,e*=d;var n=m(e);Ut(n*m(t),n*I(t),I(e))}function Ut(t,e,n){++Ct,Mt+=(t-Mt)/Ct,_t+=(e-_t)/Ct,Lt+=(n-Lt)/Ct}function Xt(){zt.point=Yt}function Yt(t,e){t*=d,e*=d;var n=m(e);Gt=n*m(t),Vt=n*I(t),qt=I(e),zt.point=Wt,Ut(Gt,Vt,qt)}function Wt(t,e){t*=d,e*=d;var n=m(e),r=n*m(t),i=n*I(t),o=I(e),s=y(C((s=Vt*o-qt*i)*s+(s=qt*r-Gt*o)*s+(s=Gt*i-Vt*r)*s),Gt*r+Vt*i+qt*o);St+=s,Pt+=s*(Gt+(Gt=r)),Rt+=s*(Vt+(Vt=i)),Tt+=s*(qt+(qt=o)),Ut(Gt,Vt,qt)}function Ht(){zt.point=jt}function Jt(){zt.point=Kt}function Zt(){$t(Ft,kt),zt.point=jt}function Kt(t,e){Ft=t,kt=e,t*=d,e*=d,zt.point=$t;var n=m(e);Gt=n*m(t),Vt=n*I(t),qt=I(e),Ut(Gt,Vt,qt)}function $t(t,e){t*=d,e*=d;var n=m(e),r=n*m(t),i=n*I(t),o=I(e),s=Vt*o-qt*i,a=qt*r-Gt*o,u=Gt*i-Vt*r,l=C(s*s+a*a+u*u),c=_(l),h=l&&-c/l;Ot+=h*s,At+=h*a,Dt+=h*u,St+=c,Pt+=c*(Gt+(Gt=r)),Rt+=c*(Vt+(Vt=i)),Tt+=c*(qt+(qt=o)),Ut(Gt,Vt,qt)}var Qt=function(t){Ct=St=Mt=_t=Lt=Pt=Rt=Tt=Ot=At=Dt=0,B(t,zt);var e=Ot,n=At,r=Dt,i=e*e+n*n+r*r;return il?t+Math.round(-t/f)*f:t,e]}function re(t,e,n){return(t%=f)?e||n?ee(oe(t),se(e,n)):oe(t):e||n?se(e,n):ne}function ie(t){return function(e,n){return e+=t,[e>l?e-f:e<-l?e+f:e,n]}}function oe(t){var e=ie(t);return e.invert=ie(-t),e}function se(t,e){var n=m(t),r=I(t),i=m(e),o=I(e);function s(t,e){var s=m(e),a=m(t)*s,u=I(t)*s,l=I(e),c=l*n+a*r;return[y(u*i-c*o,a*n-l*r),_(c*i+u*o)]}return s.invert=function(t,e){var s=m(e),a=m(t)*s,u=I(t)*s,l=I(e),c=l*i-u*o;return[y(u*i+l*o,a*n+c*r),_(c*n-a*r)]},s}ne.invert=ne;var ae=function(t){function e(e){return e=t(e[0]*d,e[1]*d),e[0]*=g,e[1]*=g,e}return t=re(t[0]*d,t[1]*d,t.length>2?t[2]*d:0),e.invert=function(e){return e=t.invert(e[0]*d,e[1]*d),e[0]*=g,e[1]*=g,e},e};function ue(t,e,n,r,i,o){if(n){var s=m(e),a=I(e),u=r*n;null==i?(i=e+r*f,o=e-u/2):(i=le(s,i),o=le(s,o),(r>0?io)&&(i+=r*f));for(var l,c=i;r>0?c>o:c1&&e.push(e.pop().concat(e.shift()))},result:function(){var n=e;return e=[],t=null,n}}},fe=function(t,e){return p(t[0]-e[0])=0;--o)i.point((c=l[o])[0],c[1]);else r(f.x,f.p.x,-1,i);f=f.p}f=f.o,l=f.z,g=!g}while(!f.v);i.lineEnd()}}};function pe(t){if(e=t.length){var e,n,r=0,i=t[0];while(++r=0?1:-1,A=O*T,D=A>l,F=b*P;if(ve.add(y(F*O*I(A),N*R+F*m(A))),s+=D?T+O*f:T,D^E>=n^M>=n){var k=Q(K(x),K(S));nt(k);var G=Q(o,k);nt(G);var V=(D^T>=0?-1:1)*_(G[2]);(r>V||r===V&&(k[0]||k[1]))&&(u+=D^T>=0?1:-1)}}return(s<-a||se?1:t>=e?0:NaN},xe=function(t){return 1===t.length&&(t=Ee(t)),{left:function(e,n,r,i){null==r&&(r=0),null==i&&(i=e.length);while(r>>1;t(e[o],n)<0?r=o+1:i=o}return r},right:function(e,n,r,i){null==r&&(r=0),null==i&&(i=e.length);while(r>>1;t(e[o],n)>0?i=o:r=o+1}return r}}};function Ee(t){return function(e,n){return me(t(e),n)}}var we=xe(me);we.right,we.left;var be=Array.prototype,Ie=(be.slice,be.map,function(t,e,n){t=+t,e=+e,n=(i=arguments.length)<2?(e=t,t=0,1):i<3?1:+n;var r=-1,i=0|Math.max(0,Math.ceil((e-t)/n)),o=new Array(i);while(++r=0){r=t[i],e=r.length;while(--e>=0)n[--s]=r[e]}return n};var Ce=function(t,e,n,r){return function(i){var o,s,a,u=e(i),l=he(),c=e(l),h=!1,f={point:g,lineStart:p,lineEnd:v,polygonStart:function(){f.point=y,f.lineStart=m,f.lineEnd=x,s=[],o=[]},polygonEnd:function(){f.point=g,f.lineStart=p,f.lineEnd=v,s=Ne(s);var t=ye(o,r);s.length?(h||(i.polygonStart(),h=!0),de(s,Me,t,n,i)):t&&(h||(i.polygonStart(),h=!0),i.lineStart(),n(null,null,1,i),i.lineEnd()),h&&(i.polygonEnd(),h=!1),s=o=null},sphere:function(){i.polygonStart(),i.lineStart(),n(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function g(e,n){t(e,n)&&i.point(e,n)}function d(t,e){u.point(t,e)}function p(){f.point=d,u.lineStart()}function v(){f.point=g,u.lineEnd()}function y(t,e){a.push([t,e]),c.point(t,e)}function m(){c.lineStart(),a=[]}function x(){y(a[0][0],a[0][1]),c.lineEnd();var t,e,n,r,u=c.clean(),f=l.result(),g=f.length;if(a.pop(),o.push(a),a=null,g)if(1&u){if(n=f[0],(e=n.length-1)>0){for(h||(i.polygonStart(),h=!0),i.lineStart(),t=0;t1&&2&u&&f.push(f.pop().concat(f.shift())),s.push(f.filter(Se))}return f}};function Se(t){return t.length>1}function Me(t,e){return((t=t.x)[0]<0?t[1]-c-a:c-t[1])-((e=e.x)[0]<0?e[1]-c-a:c-e[1])}var _e=Ce(function(){return!0},Le,Re,[-l,-c]);function Le(t){var e,n=NaN,r=NaN,i=NaN;return{lineStart:function(){t.lineStart(),e=1},point:function(o,s){var u=o>0?l:-l,h=p(o-n);p(h-l)0?c:-c),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(u,r),t.point(o,r),e=0):i!==u&&h>=l&&(p(n-i)a?v((I(e)*(o=m(r))*I(n)-I(r)*(i=m(e))*I(t))/(i*o*s)):(e+r)/2}function Re(t,e,n,r){var i;if(null==t)i=n*c,r.point(-l,i),r.point(0,i),r.point(l,i),r.point(l,0),r.point(l,-i),r.point(0,-i),r.point(-l,-i),r.point(-l,0),r.point(-l,i);else if(p(t[0]-e[0])>a){var o=t[0]0,i=p(e)>a;function o(e,r,i,o){ue(o,t,n,i,e,r)}function s(t,n){return m(t)*m(n)>e}function u(t){var e,n,o,u,f;return{lineStart:function(){u=o=!1,f=1},point:function(g,d){var p,v=[g,d],y=s(g,d),m=r?y?0:h(g,d):y?h(g+(g<0?l:-l),d):0;if(!e&&(u=o=y)&&t.lineStart(),y!==o&&(p=c(e,v),(!p||fe(e,p)||fe(v,p))&&(v[0]+=a,v[1]+=a,y=s(v[0],v[1]))),y!==o)f=0,y?(t.lineStart(),p=c(v,e),t.point(p[0],p[1])):(p=c(e,v),t.point(p[0],p[1]),t.lineEnd()),e=p;else if(i&&e&&r^y){var x;m&n||!(x=c(v,e,!0))||(f=0,r?(t.lineStart(),t.point(x[0][0],x[0][1]),t.point(x[1][0],x[1][1]),t.lineEnd()):(t.point(x[1][0],x[1][1]),t.lineEnd(),t.lineStart(),t.point(x[0][0],x[0][1])))}!y||e&&fe(e,v)||t.point(v[0],v[1]),e=v,o=y,n=m},lineEnd:function(){o&&t.lineEnd(),e=null},clean:function(){return f|(u&&o)<<1}}}function c(t,n,r){var i=K(t),o=K(n),s=[1,0,0],u=Q(i,o),c=$(u,u),h=u[0],f=c-h*h;if(!f)return!r&&t;var g=e*c/f,d=-e*h/f,v=Q(s,u),y=et(s,g),m=et(u,d);tt(y,m);var x=v,E=$(y,x),w=$(x,x),b=E*E-w*($(y,y)-1);if(!(b<0)){var I=C(b),N=et(x,(-E-I)/w);if(tt(N,y),N=Z(N),!r)return N;var S,M=t[0],_=n[0],L=t[1],P=n[1];_0^N[1]<(p(N[0]-M)l^(M<=N[0]&&N[0]<=_)){var A=et(x,(-E+I)/w);return tt(A,y),[N,Z(A)]}}}function h(e,n){var i=r?t:l-t,o=0;return e<-i?o|=1:e>i&&(o|=2),n<-i?o|=4:n>i&&(o|=8),o}return Ce(s,u,o,r?[0,-t]:[-l,t-l])},Oe=function(t,e,n,r,i,o){var s,a=t[0],u=t[1],l=e[0],c=e[1],h=0,f=1,g=l-a,d=c-u;if(s=n-a,g||!(s>0)){if(s/=g,g<0){if(s0){if(s>f)return;s>h&&(h=s)}if(s=i-a,g||!(s<0)){if(s/=g,g<0){if(s>f)return;s>h&&(h=s)}else if(g>0){if(s0)){if(s/=d,d<0){if(s0){if(s>f)return;s>h&&(h=s)}if(s=o-u,d||!(s<0)){if(s/=d,d<0){if(s>f)return;s>h&&(h=s)}else if(d>0){if(s0&&(t[0]=a+h*g,t[1]=u+h*d),f<1&&(e[0]=a+f*g,e[1]=u+f*d),!0}}}}},Ae=1e9,De=-Ae;function Fe(t,e,n,r){function i(i,o){return t<=i&&i<=n&&e<=o&&o<=r}function o(i,o,a,u){var c=0,h=0;if(null==i||(c=s(i,a))!==(h=s(o,a))||l(i,o)<0^a>0)do{u.point(0===c||3===c?t:n,c>1?r:e)}while((c=(c+a+4)%4)!==h);else u.point(o[0],o[1])}function s(r,i){return p(r[0]-t)0?0:3:p(r[0]-n)0?2:1:p(r[1]-e)0?1:0:i>0?3:2}function u(t,e){return l(t.x,e.x)}function l(t,e){var n=s(t,1),r=s(e,1);return n!==r?n-r:0===n?e[1]-t[1]:1===n?t[0]-e[0]:2===n?t[1]-e[1]:e[0]-t[0]}return function(s){var a,l,c,h,f,g,d,p,v,y,m,x=s,E=he(),w={point:b,lineStart:S,lineEnd:M,polygonStart:N,polygonEnd:C};function b(t,e){i(t,e)&&x.point(t,e)}function I(){for(var e=0,n=0,i=l.length;nr&&(f-o)*(r-s)>(g-s)*(t-o)&&++e:g<=r&&(f-o)*(r-s)<(g-s)*(t-o)&&--e;return e}function N(){x=E,a=[],l=[],m=!0}function C(){var t=I(),e=m&&t,n=(a=Ne(a)).length;(e||n)&&(s.polygonStart(),e&&(s.lineStart(),o(null,null,1,s),s.lineEnd()),n&&de(a,u,t,o,s),s.polygonEnd()),x=s,a=l=c=null}function S(){w.point=_,l&&l.push(c=[]),y=!0,v=!1,d=p=NaN}function M(){a&&(_(h,f),g&&v&&E.rejoin(),a.push(E.result())),w.point=b,v&&x.lineEnd()}function _(o,s){var a=i(o,s);if(l&&c.push([o,s]),y)h=o,f=s,g=a,y=!1,a&&(x.lineStart(),x.point(o,s));else if(a&&v)x.point(o,s);else{var u=[d=Math.max(De,Math.min(Ae,d)),p=Math.max(De,Math.min(Ae,p))],E=[o=Math.max(De,Math.min(Ae,o)),s=Math.max(De,Math.min(Ae,s))];Oe(u,E,t,e,n,r)?(v||(x.lineStart(),x.point(u[0],u[1])),x.point(E[0],E[1]),a||x.lineEnd(),m=!1):a&&(x.lineStart(),x.point(o,s),m=!1)}d=o,p=s,v=a}return w}}var ke,Ge,Ve,qe=function(){var t,e,n,r=0,i=0,o=960,s=500;return n={stream:function(n){return t&&e===n?t:t=Fe(r,i,o,s)(e=n)},extent:function(a){return arguments.length?(r=+a[0][0],i=+a[0][1],o=+a[1][0],s=+a[1][1],t=e=null,n):[[r,i],[o,s]]}}},Be=r(),ze={sphere:P,point:P,lineStart:je,lineEnd:P,polygonStart:P,polygonEnd:P};function je(){ze.point=Xe,ze.lineEnd=Ue}function Ue(){ze.point=ze.lineEnd=P}function Xe(t,e){t*=d,e*=d,ke=t,Ge=I(e),Ve=m(e),ze.point=Ye}function Ye(t,e){t*=d,e*=d;var n=I(e),r=m(e),i=p(t-ke),o=m(i),s=I(i),a=r*s,u=Ve*n-Ge*r*o,l=Ge*n+Ve*r*o;Be.add(y(C(a*a+u*u),l)),ke=t,Ge=n,Ve=r}var We=function(t){return Be.reset(),B(t,ze),+Be},He=[null,null],Je={type:\\\"LineString\\\",coordinates:He},Ze=function(t,e){return He[0]=t,He[1]=e,We(Je)},Ke={Feature:function(t,e){return Qe(t.geometry,e)},FeatureCollection:function(t,e){var n=t.features,r=-1,i=n.length;while(++ra}).map(l)).concat(Ie(x(o/d)*d,i,d).filter(function(t){return p(t%y)>a}).map(c))}return E.lines=function(){return w().map(function(t){return{type:\\\"LineString\\\",coordinates:t}})},E.outline=function(){return{type:\\\"Polygon\\\",coordinates:[h(r).concat(f(s).slice(1),h(n).reverse().slice(1),f(u).reverse().slice(1))]}},E.extent=function(t){return arguments.length?E.extentMajor(t).extentMinor(t):E.extentMinor()},E.extentMajor=function(t){return arguments.length?(r=+t[0][0],n=+t[1][0],u=+t[0][1],s=+t[1][1],r>n&&(t=r,r=n,n=t),u>s&&(t=u,u=s,s=t),E.precision(m)):[[r,u],[n,s]]},E.extentMinor=function(n){return arguments.length?(e=+n[0][0],t=+n[1][0],o=+n[0][1],i=+n[1][1],e>t&&(n=e,e=t,t=n),o>i&&(n=o,o=i,i=n),E.precision(m)):[[e,o],[t,i]]},E.step=function(t){return arguments.length?E.stepMajor(t).stepMinor(t):E.stepMinor()},E.stepMajor=function(t){return arguments.length?(v=+t[0],y=+t[1],E):[v,y]},E.stepMinor=function(t){return arguments.length?(g=+t[0],d=+t[1],E):[g,d]},E.precision=function(a){return arguments.length?(m=+a,l=an(o,i,90),c=un(e,t,m),h=an(u,s,90),f=un(r,n,m),E):m},E.extentMajor([[-180,-90+a],[180,90-a]]).extentMinor([[-180,-80-a],[180,80+a]])}function cn(){return ln()()}var hn,fn,gn,dn,pn=function(t,e){var n=t[0]*d,r=t[1]*d,i=e[0]*d,o=e[1]*d,s=m(r),a=I(r),u=m(o),l=I(o),c=s*m(n),h=s*I(n),f=u*m(i),p=u*I(i),v=2*_(C(L(o-r)+s*u*L(i-n))),x=I(v),E=v?function(t){var e=I(t*=v)/x,n=I(v-t)/x,r=n*c+e*f,i=n*h+e*p,o=n*a+e*l;return[y(i,r)*g,y(o,C(r*r+i*i))*g]}:function(){return[n*g,r*g]};return E.distance=v,E},vn=function(t){return t},yn=r(),mn=r(),xn={point:P,lineStart:P,lineEnd:P,polygonStart:function(){xn.lineStart=En,xn.lineEnd=In},polygonEnd:function(){xn.lineStart=xn.lineEnd=xn.point=P,yn.add(p(mn)),mn.reset()},result:function(){var t=yn/2;return yn.reset(),t}};function En(){xn.point=wn}function wn(t,e){xn.point=bn,hn=gn=t,fn=dn=e}function bn(t,e){mn.add(dn*t-gn*e),gn=t,dn=e}function In(){bn(hn,fn)}var Nn=xn,Cn=1/0,Sn=Cn,Mn=-Cn,_n=Mn,Ln={point:Pn,lineStart:P,lineEnd:P,polygonStart:P,polygonEnd:P,result:function(){var t=[[Cn,Sn],[Mn,_n]];return Mn=_n=-(Sn=Cn=1/0),t}};function Pn(t,e){tMn&&(Mn=t),e_n&&(_n=e)}var Rn,Tn,On,An,Dn=Ln,Fn=0,kn=0,Gn=0,Vn=0,qn=0,Bn=0,zn=0,jn=0,Un=0,Xn={point:Yn,lineStart:Wn,lineEnd:Zn,polygonStart:function(){Xn.lineStart=Kn,Xn.lineEnd=$n},polygonEnd:function(){Xn.point=Yn,Xn.lineStart=Wn,Xn.lineEnd=Zn},result:function(){var t=Un?[zn/Un,jn/Un]:Bn?[Vn/Bn,qn/Bn]:Gn?[Fn/Gn,kn/Gn]:[NaN,NaN];return Fn=kn=Gn=Vn=qn=Bn=zn=jn=Un=0,t}};function Yn(t,e){Fn+=t,kn+=e,++Gn}function Wn(){Xn.point=Hn}function Hn(t,e){Xn.point=Jn,Yn(On=t,An=e)}function Jn(t,e){var n=t-On,r=e-An,i=C(n*n+r*r);Vn+=i*(On+t)/2,qn+=i*(An+e)/2,Bn+=i,Yn(On=t,An=e)}function Zn(){Xn.point=Yn}function Kn(){Xn.point=Qn}function $n(){tr(Rn,Tn)}function Qn(t,e){Xn.point=tr,Yn(Rn=On=t,Tn=An=e)}function tr(t,e){var n=t-On,r=e-An,i=C(n*n+r*r);Vn+=i*(On+t)/2,qn+=i*(An+e)/2,Bn+=i,i=An*t-On*e,zn+=i*(On+t),jn+=i*(An+e),Un+=3*i,Yn(On=t,An=e)}var er=Xn;function nr(t){this._context=t}nr.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,e){switch(this._point){case 0:this._context.moveTo(t,e),this._point=1;break;case 1:this._context.lineTo(t,e);break;default:this._context.moveTo(t+this._radius,e),this._context.arc(t,e,this._radius,0,f);break}},result:P};var rr,ir,or,sr,ar,ur=r(),lr={point:P,lineStart:function(){lr.point=cr},lineEnd:function(){rr&&hr(ir,or),lr.point=P},polygonStart:function(){rr=!0},polygonEnd:function(){rr=null},result:function(){var t=+ur;return ur.reset(),t}};function cr(t,e){lr.point=hr,ir=sr=t,or=ar=e}function hr(t,e){sr-=t,ar-=e,ur.add(C(sr*sr+ar*ar)),sr=t,ar=e}var fr=lr;function gr(){this._string=[]}function dr(t){return\\\"m0,\\\"+t+\\\"a\\\"+t+\\\",\\\"+t+\\\" 0 1,1 0,\\\"+-2*t+\\\"a\\\"+t+\\\",\\\"+t+\\\" 0 1,1 0,\\\"+2*t+\\\"z\\\"}gr.prototype={_radius:4.5,_circle:dr(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push(\\\"Z\\\"),this._point=NaN},point:function(t,e){switch(this._point){case 0:this._string.push(\\\"M\\\",t,\\\",\\\",e),this._point=1;break;case 1:this._string.push(\\\"L\\\",t,\\\",\\\",e);break;default:null==this._circle&&(this._circle=dr(this._radius)),this._string.push(\\\"M\\\",t,\\\",\\\",e,this._circle);break}},result:function(){if(this._string.length){var t=this._string.join(\\\"\\\");return this._string=[],t}return null}};var pr=function(t,e){var n,r,i=4.5;function o(t){return t&&(\\\"function\\\"===typeof i&&r.pointRadius(+i.apply(this,arguments)),B(t,n(r))),r.result()}return o.area=function(t){return B(t,n(Nn)),Nn.result()},o.measure=function(t){return B(t,n(fr)),fr.result()},o.bounds=function(t){return B(t,n(Dn)),Dn.result()},o.centroid=function(t){return B(t,n(er)),er.result()},o.projection=function(e){return arguments.length?(n=null==e?(t=null,vn):(t=e).stream,o):t},o.context=function(t){return arguments.length?(r=null==t?(e=null,new gr):new nr(e=t),\\\"function\\\"!==typeof i&&r.pointRadius(i),o):e},o.pointRadius=function(t){return arguments.length?(i=\\\"function\\\"===typeof t?t:(r.pointRadius(+t),+t),o):i},o.projection(t).context(e)},vr=function(t){return{stream:yr(t)}};function yr(t){return function(e){var n=new mr;for(var r in t)n[r]=t[r];return n.stream=e,n}}function mr(){}function xr(t,e,n){var r=t.clipExtent&&t.clipExtent();return t.scale(150).translate([0,0]),null!=r&&t.clipExtent(null),B(n,t.stream(Dn)),e(Dn.result()),null!=r&&t.clipExtent(r),t}function Er(t,e,n){return xr(t,function(n){var r=e[1][0]-e[0][0],i=e[1][1]-e[0][1],o=Math.min(r/(n[1][0]-n[0][0]),i/(n[1][1]-n[0][1])),s=+e[0][0]+(r-o*(n[1][0]+n[0][0]))/2,a=+e[0][1]+(i-o*(n[1][1]+n[0][1]))/2;t.scale(150*o).translate([s,a])},n)}function wr(t,e,n){return Er(t,[[0,0],e],n)}function br(t,e,n){return xr(t,function(n){var r=+e,i=r/(n[1][0]-n[0][0]),o=(r-i*(n[1][0]+n[0][0]))/2,s=-i*n[0][1];t.scale(150*i).translate([o,s])},n)}function Ir(t,e,n){return xr(t,function(n){var r=+e,i=r/(n[1][1]-n[0][1]),o=-i*n[0][0],s=(r-i*(n[1][1]+n[0][1]))/2;t.scale(150*i).translate([o,s])},n)}mr.prototype={constructor:mr,point:function(t,e){this.stream.point(t,e)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};var Nr=16,Cr=m(30*d),Sr=function(t,e){return+e?_r(t,e):Mr(t)};function Mr(t){return yr({point:function(e,n){e=t(e,n),this.stream.point(e[0],e[1])}})}function _r(t,e){function n(r,i,o,s,u,l,c,h,f,g,d,v,m,x){var E=c-r,w=h-i,b=E*E+w*w;if(b>4*e&&m--){var I=s+g,N=u+d,S=l+v,M=C(I*I+N*N+S*S),L=_(S/=M),P=p(p(S)-1)e||p((E*A+w*D)/b-.5)>.3||s*g+u*d+l*v2?t[2]%360*d:0,P()):[m*g,x*g,E*g]},_.angle=function(t){return arguments.length?(w=t%360*d,P()):w*g},_.precision=function(t){return arguments.length?(s=Sr(a,M=t*t),R()):C(M)},_.fitExtent=function(t,e){return Er(_,t,e)},_.fitSize=function(t,e){return wr(_,t,e)},_.fitWidth=function(t,e){return br(_,t,e)},_.fitHeight=function(t,e){return Ir(_,t,e)},function(){return e=t.apply(this,arguments),_.invert=e.invert&&L,P()}}function Dr(t){var e=0,n=l/3,r=Ar(t),i=r(e,n);return i.parallels=function(t){return arguments.length?r(e=t[0]*d,n=t[1]*d):[e*g,n*g]},i}function Fr(t){var e=m(t);function n(t,n){return[t*e,I(n)/e]}return n.invert=function(t,n){return[t/e,_(n*e)]},n}function kr(t,e){var n=I(t),r=(n+I(e))/2;if(p(r)=.12&&i<.234&&r>=-.425&&r<-.214?u:i>=.166&&i<.234&&r>=-.214&&r<-.115?l:s).invert(t)},h.stream=function(n){return t&&e===n?t:t=qr([s.stream(e=n),u.stream(n),l.stream(n)])},h.precision=function(t){return arguments.length?(s.precision(t),u.precision(t),l.precision(t),f()):s.precision()},h.scale=function(t){return arguments.length?(s.scale(t),u.scale(.35*t),l.scale(t),h.translate(s.translate())):s.scale()},h.translate=function(t){if(!arguments.length)return s.translate();var e=s.scale(),o=+t[0],h=+t[1];return n=s.translate(t).clipExtent([[o-.455*e,h-.238*e],[o+.455*e,h+.238*e]]).stream(c),r=u.translate([o-.307*e,h+.201*e]).clipExtent([[o-.425*e+a,h+.12*e+a],[o-.214*e-a,h+.234*e-a]]).stream(c),i=l.translate([o-.205*e,h+.212*e]).clipExtent([[o-.214*e+a,h+.166*e+a],[o-.115*e-a,h+.234*e-a]]).stream(c),f()},h.fitExtent=function(t,e){return Er(h,t,e)},h.fitSize=function(t,e){return wr(h,t,e)},h.fitWidth=function(t,e){return br(h,t,e)},h.fitHeight=function(t,e){return Ir(h,t,e)},h.scale(1070)};function zr(t){return function(e,n){var r=m(e),i=m(n),o=t(r*i);return[o*i*I(e),o*I(n)]}}function jr(t){return function(e,n){var r=C(e*e+n*n),i=t(r),o=I(i),s=m(i);return[y(e*o,r*s),_(r&&n*o/r)]}}var Ur=zr(function(t){return C(2/(1+t))});Ur.invert=jr(function(t){return 2*_(t/2)});var Xr=function(){return Or(Ur).scale(124.75).clipAngle(179.999)},Yr=zr(function(t){return(t=M(t))&&t/I(t)});Yr.invert=jr(function(t){return t});var Wr=function(){return Or(Yr).scale(79.4188).clipAngle(179.999)};function Hr(t,e){return[t,w(S((c+e)/2))]}Hr.invert=function(t,e){return[t,2*v(E(e))-c]};var Jr=function(){return Zr(Hr).scale(961/f)};function Zr(t){var e,n,r,i=Or(t),o=i.center,s=i.scale,a=i.translate,u=i.clipExtent,c=null;function h(){var o=l*s(),a=i(ae(i.rotate()).invert([0,0]));return u(null==c?[[a[0]-o,a[1]-o],[a[0]+o,a[1]+o]]:t===Hr?[[Math.max(a[0]-o,c),e],[Math.min(a[0]+o,n),r]]:[[c,Math.max(a[1]-o,e)],[n,Math.min(a[1]+o,r)]])}return i.scale=function(t){return arguments.length?(s(t),h()):s()},i.translate=function(t){return arguments.length?(a(t),h()):a()},i.center=function(t){return arguments.length?(o(t),h()):o()},i.clipExtent=function(t){return arguments.length?(null==t?c=e=n=r=null:(c=+t[0][0],e=+t[0][1],n=+t[1][0],r=+t[1][1]),h()):null==c?null:[[c,e],[n,r]]},h()}function Kr(t){return S((c+t)/2)}function $r(t,e){var n=m(t),r=t===e?I(t):w(n/m(e))/w(Kr(e)/Kr(t)),i=n*b(Kr(t),r)/r;if(!r)return Hr;function o(t,e){i>0?e<-c+a&&(e=-c+a):e>c-a&&(e=c-a);var n=i/b(Kr(e),r);return[n*I(r*t),i-n*m(r*t)]}return o.invert=function(t,e){var n=i-e,o=N(r)*C(t*t+n*n);return[y(t,p(n))/r*N(n),2*v(b(i/o,1/r))-c]},o}var Qr=function(){return Dr($r).scale(109.5).parallels([30,30])};function ti(t,e){return[t,e]}ti.invert=ti;var ei=function(){return Or(ti).scale(152.63)};function ni(t,e){var n=m(t),r=t===e?I(t):(n-m(e))/(e-t),i=n/r+t;if(p(r)a&&--i>0);return[t/(.8707+(o=r*r)*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979)),r]};var yi=function(){return Or(vi).scale(175.295)};function mi(t,e){return[m(e)*I(t),I(e)]}mi.invert=jr(_);var xi=function(){return Or(mi).scale(249.5).clipAngle(90+a)};function Ei(t,e){var n=m(e),r=1+m(t)*n;return[n*I(t)/r,I(e)/r]}Ei.invert=jr(function(t){return 2*v(t)});var wi=function(){return Or(Ei).scale(250).clipAngle(142)};function bi(t,e){return[w(S((c+e)/2)),-t]}bi.invert=function(t,e){return[-e,2*v(E(t))-c]};var Ii=function(){var t=Zr(bi),e=t.center,n=t.rotate;return t.center=function(t){return arguments.length?e([-t[1],t[0]]):(t=e(),[t[1],-t[0]])},t.rotate=function(t){return arguments.length?n([t[0],t[1],t.length>2?t[2]+90:90]):(t=n(),[t[0],t[1],t[2]-90])},n([0,0,90]).scale(159.155)};n.d(e,\\\"geoArea\\\",function(){return J}),n.d(e,\\\"geoBounds\\\",function(){return Bt}),n.d(e,\\\"geoCentroid\\\",function(){return Qt}),n.d(e,\\\"geoCircle\\\",function(){return ce}),n.d(e,\\\"geoClipAntimeridian\\\",function(){return _e}),n.d(e,\\\"geoClipCircle\\\",function(){return Te}),n.d(e,\\\"geoClipExtent\\\",function(){return qe}),n.d(e,\\\"geoClipRectangle\\\",function(){return Fe}),n.d(e,\\\"geoContains\\\",function(){return sn}),n.d(e,\\\"geoDistance\\\",function(){return Ze}),n.d(e,\\\"geoGraticule\\\",function(){return ln}),n.d(e,\\\"geoGraticule10\\\",function(){return cn}),n.d(e,\\\"geoInterpolate\\\",function(){return pn}),n.d(e,\\\"geoLength\\\",function(){return We}),n.d(e,\\\"geoPath\\\",function(){return pr}),n.d(e,\\\"geoAlbers\\\",function(){return Vr}),n.d(e,\\\"geoAlbersUsa\\\",function(){return Br}),n.d(e,\\\"geoAzimuthalEqualArea\\\",function(){return Xr}),n.d(e,\\\"geoAzimuthalEqualAreaRaw\\\",function(){return Ur}),n.d(e,\\\"geoAzimuthalEquidistant\\\",function(){return Wr}),n.d(e,\\\"geoAzimuthalEquidistantRaw\\\",function(){return Yr}),n.d(e,\\\"geoConicConformal\\\",function(){return Qr}),n.d(e,\\\"geoConicConformalRaw\\\",function(){return $r}),n.d(e,\\\"geoConicEqualArea\\\",function(){return Gr}),n.d(e,\\\"geoConicEqualAreaRaw\\\",function(){return kr}),n.d(e,\\\"geoConicEquidistant\\\",function(){return ri}),n.d(e,\\\"geoConicEquidistantRaw\\\",function(){return ni}),n.d(e,\\\"geoEqualEarth\\\",function(){return hi}),n.d(e,\\\"geoEqualEarthRaw\\\",function(){return ci}),n.d(e,\\\"geoEquirectangular\\\",function(){return ei}),n.d(e,\\\"geoEquirectangularRaw\\\",function(){return ti}),n.d(e,\\\"geoGnomonic\\\",function(){return gi}),n.d(e,\\\"geoGnomonicRaw\\\",function(){return fi}),n.d(e,\\\"geoIdentity\\\",function(){return pi}),n.d(e,\\\"geoProjection\\\",function(){return Or}),n.d(e,\\\"geoProjectionMutator\\\",function(){return Ar}),n.d(e,\\\"geoMercator\\\",function(){return Jr}),n.d(e,\\\"geoMercatorRaw\\\",function(){return Hr}),n.d(e,\\\"geoNaturalEarth1\\\",function(){return yi}),n.d(e,\\\"geoNaturalEarth1Raw\\\",function(){return vi}),n.d(e,\\\"geoOrthographic\\\",function(){return xi}),n.d(e,\\\"geoOrthographicRaw\\\",function(){return mi}),n.d(e,\\\"geoStereographic\\\",function(){return wi}),n.d(e,\\\"geoStereographicRaw\\\",function(){return Ei}),n.d(e,\\\"geoTransverseMercator\\\",function(){return Ii}),n.d(e,\\\"geoTransverseMercatorRaw\\\",function(){return bi}),n.d(e,\\\"geoRotation\\\",function(){return ae}),n.d(e,\\\"geoStream\\\",function(){return B}),n.d(e,\\\"geoTransform\\\",function(){return vr})},a026:function(t,e,n){\\\"use strict\\\";function r(t,e){var n=t+e,r=n-t,i=n-r,o=e-r,s=t-i,a=s+o;return a?[a,n]:[n]}function i(t,e){var n=0|t.length,i=0|e.length;if(1===n&&1===i)return r(t[0],e[0]);var o,s,a=n+i,u=new Array(a),l=0,c=0,h=0,f=Math.abs,g=t[c],d=f(g),p=e[h],v=f(p);d=i?(o=g,c+=1,c0)-(t<0)},e.abs=function(t){var e=t>>r-1;return(t^e)-e},e.min=function(t,e){return e^(t^e)&-(t65535)<<4,t>>>=e,n=(t>255)<<3,t>>>=n,e|=n,n=(t>15)<<2,t>>>=n,e|=n,n=(t>3)<<1,t>>>=n,e|=n,e|t>>1},e.log10=function(t){return t>=1e9?9:t>=1e8?8:t>=1e7?7:t>=1e6?6:t>=1e5?5:t>=1e4?4:t>=1e3?3:t>=100?2:t>=10?1:0},e.popCount=function(t){return t-=t>>>1&1431655765,t=(858993459&t)+(t>>>2&858993459),16843009*(t+(t>>>4)&252645135)>>>24},e.countTrailingZeros=i,e.nextPow2=function(t){return t+=0===t,--t,t|=t>>>1,t|=t>>>2,t|=t>>>4,t|=t>>>8,t|=t>>>16,t+1},e.prevPow2=function(t){return t|=t>>>1,t|=t>>>2,t|=t>>>4,t|=t>>>8,t|=t>>>16,t-(t>>>1)},e.parity=function(t){return t^=t>>>16,t^=t>>>8,t^=t>>>4,t&=15,27030>>>t&1};var o=new Array(256);(function(t){for(var e=0;e<256;++e){var n=e,r=e,i=7;for(n>>>=1;n;n>>>=1)r<<=1,r|=1&n,--i;t[e]=r<>>8&255]<<16|o[t>>>16&255]<<8|o[t>>>24&255]},e.interleave2=function(t,e){return t&=65535,t=16711935&(t|t<<8),t=252645135&(t|t<<4),t=858993459&(t|t<<2),t=1431655765&(t|t<<1),e&=65535,e=16711935&(e|e<<8),e=252645135&(e|e<<4),e=858993459&(e|e<<2),e=1431655765&(e|e<<1),t|e<<1},e.deinterleave2=function(t,e){return t=t>>>e&1431655765,t=858993459&(t|t>>>1),t=252645135&(t|t>>>2),t=16711935&(t|t>>>4),t=65535&(t|t>>>16),t<<16>>16},e.interleave3=function(t,e,n){return t&=1023,t=4278190335&(t|t<<16),t=251719695&(t|t<<8),t=3272356035&(t|t<<4),t=1227133513&(t|t<<2),e&=1023,e=4278190335&(e|e<<16),e=251719695&(e|e<<8),e=3272356035&(e|e<<4),e=1227133513&(e|e<<2),t|=e<<1,n&=1023,n=4278190335&(n|n<<16),n=251719695&(n|n<<8),n=3272356035&(n|n<<4),n=1227133513&(n|n<<2),t|n<<2},e.deinterleave3=function(t,e){return t=t>>>e&1227133513,t=3272356035&(t|t>>>2),t=251719695&(t|t>>>4),t=4278190335&(t|t>>>8),t=1023&(t|t>>>16),t<<22>>22},e.nextCombination=function(t){var e=t|t-1;return e+1|(~e&-~e)-1>>>i(t)+1}},a4e0:function(t,e,n){var r=n(\\\"feb7\\\").point;function i(t,e,n,r,i,o,s,a){var u,l,c,h,f,g={x:null,y:null,onLine1:!1,onLine2:!1};return u=(a-o)*(n-t)-(s-i)*(r-e),0===u?null!==g.x&&null!==g.y&&g:(l=e-o,c=t-i,h=(s-i)*l-(a-o)*c,f=(n-t)*l-(r-e)*c,l=h/u,c=f/u,g.x=t+l*(n-t),g.y=e+l*(r-e),l>=0&&l<=1&&(g.onLine1=!0),c>=0&&c<=1&&(g.onLine2=!0),!(!g.onLine1||!g.onLine2)&&[g.x,g.y])}t.exports=function(t){var e,n,o={type:\\\"FeatureCollection\\\",features:[]};if(n=\\\"Feature\\\"===t.type?t.geometry:t,\\\"LineString\\\"===n.type)e=[n.coordinates];else if(\\\"MultiLineString\\\"===n.type)e=n.coordinates;else if(\\\"MultiPolygon\\\"===n.type)e=[].concat.apply([],n.coordinates);else{if(\\\"Polygon\\\"!==n.type)throw new Error(\\\"Input must be a LineString, MultiLineString, Polygon, or MultiPolygon Feature or Geometry\\\");e=n.coordinates}return e.forEach(function(t){e.forEach(function(e){for(var n=0;n1?t:null;case\\\"MultiPolygon\\\":var e=[];if(a(t,function(t){i(t)>1&&e.push(t.geometry.coordinates)}),e.length)return{type:\\\"MultiPolygon\\\",coordinates:e}}}t.exports=function(t,e){var n=s(t),i=s(e),a=t.properties||{};if(n=u(n),i=u(i),!n)return null;if(!i)return o(n,a);var l=new r.io.GeoJSONReader,c=l.read(n),h=l.read(i),f=c.difference(h);if(f.isEmpty())return null;var g=new r.io.GeoJSONWriter,d=g.write(f);return o(d,a)}},a8e7:function(t,e,n){var r=n(\\\"0354\\\"),i=function(){var t={};return Array.prototype.slice.call(arguments).forEach(function(e){e&&Object.keys(e).forEach(function(n){t[n]=e[n]})}),t};function o(t,e,n,r){if(s(t,n)||s(t,r)||s(e,n)||s(r,n))return null;var i=t[0],o=t[1],a=e[0],u=e[1],l=n[0],c=n[1],h=r[0],f=r[1],g=(i-a)*(c-f)-(o-u)*(l-h);if(0==g)return null;var d=((i*u-o*a)*(l-h)-(i-a)*(l*f-c*h))/g,p=((i*u-o*a)*(c-f)-(o-u)*(l*f-c*h))/g;return[d,p]}function s(t,e){if(!t||!e)return!1;if(t.length!=e.length)return!1;for(var n=0,r=t.length;n=(t-1)*(t-1)||e>=t*t}function m(t){return t<0-s.epsilon||t>1+s.epsilon}function x(t,n,r,i){var c=a[t][n],h=a[t][n+1],f=a[r][i],g=a[r][i+1],d=o(c,h,f,g);if(null!=d){if(h[0]!=c[0])var p=(d[0]-c[0])/(h[0]-c[0]);else p=(d[1]-c[1])/(h[1]-c[1]);if(g[0]!=f[0])var v=(d[0]-f[0])/(g[0]-f[0]);else v=(d[1]-f[1])/(g[1]-f[1]);if(!m(p)&&!m(v)&&(!y(p)||!y(v)||s.reportVertexOnVertex)&&(!y(p)&&!y(v)||s.reportVertexOnEdge)){var x=d,E=!l[x];E&&(l[x]=!0),e?u.push(e(d,t,n,c,h,p,r,i,f,g,v,E)):u.push(d)}}}function E(t,e){var n=a[t][e],r=a[t][e+1];if(n[0]0){var l=u.map(function(t){return r[t.index]=!0,e.remove({index:t.index},f),t.geojson});l.push(t),t=i.apply(this,l)}if(0===u.length)break}n.push(t)}),o.featureCollection(n)}function f(t,e){return t.index===e.index}function g(t){var e=r(),n=[];return a(t,function(t,e){var r=s(t);n.push({minX:r[0],minY:r[1],maxX:r[2],maxY:r[3],geojson:t,index:e})}),e.load(n),e}t.exports=function(t,e){var n=c(e),r=l(t),i=r[0],o=r[1];i=h(i),o=h(o);var s=u(n,i,o);return s}},aae3:function(t,e,n){var r=n(\\\"d3f4\\\"),i=n(\\\"2d95\\\"),o=n(\\\"2b4c\\\")(\\\"match\\\");t.exports=function(t){var e;return r(t)&&(void 0!==(e=t[o])?!!e:\\\"RegExp\\\"==i(t))}},ac6a:function(t,e,n){for(var r=n(\\\"cadf\\\"),i=n(\\\"0d58\\\"),o=n(\\\"2aba\\\"),s=n(\\\"7726\\\"),a=n(\\\"32e9\\\"),u=n(\\\"84f2\\\"),l=n(\\\"2b4c\\\"),c=l(\\\"iterator\\\"),h=l(\\\"toStringTag\\\"),f=u.Array,g={CSSRuleList:!0,CSSStyleDeclaration:!1,CSSValueList:!1,ClientRectList:!1,DOMRectList:!1,DOMStringList:!1,DOMTokenList:!0,DataTransferItemList:!1,FileList:!1,HTMLAllCollection:!1,HTMLCollection:!1,HTMLFormElement:!1,HTMLSelectElement:!1,MediaList:!0,MimeTypeArray:!1,NamedNodeMap:!1,NodeList:!0,PaintRequestList:!1,Plugin:!1,PluginArray:!1,SVGLengthList:!1,SVGNumberList:!1,SVGPathSegList:!1,SVGPointList:!1,SVGStringList:!1,SVGTransformList:!1,SourceBufferList:!1,StyleSheetList:!0,TextTrackCueList:!1,TextTrackList:!1,TouchList:!1},d=i(g),p=0;p0?f:h;break}break;case\\\"bearing+endpoint\\\":d=Math.sign(i.cross(l).dot(h)),g=d>0?h:f;break;case\\\"endpoint+bearing\\\":p=Math.sign(s.cross(c).dot(h)),g=p>0?h:f;break;case\\\"endpoint+endpoint\\\":var v=l.plus(c).plus(e.toVector()).plus(r.toVector());g=v.dot(h)>0?h:f;break}return g.toLatLonS()},o.prototype.crossTrackDistanceTo=function(t,e,n){if(!(t instanceof o))throw new TypeError(\\\"pathStart is not LatLon object\\\");var r=void 0===n?6371e3:Number(n),i=this.toVector(),s=e instanceof o?t.toVector().cross(e.toVector()):t.greatCircle(Number(e)),a=s.angleTo(i)-Math.PI/2,u=a*r;return u},o.prototype.alongTrackDistanceTo=function(t,e,n){if(!(t instanceof o))throw new TypeError(\\\"pathStart is not LatLon object\\\");var r=void 0===n?6371e3:Number(n),i=this.toVector(),s=e instanceof o?t.toVector().cross(e.toVector()):t.greatCircle(Number(e)),a=s.cross(i).cross(s),u=t.toVector().angleTo(a,s),l=u*r;return l},o.prototype.nearestPointOnSegment=function(t,e){var n=null;if(this.isBetween(t,e)){var r=this.toVector(),i=t.toVector(),o=e.toVector(),s=i.cross(o),a=r.cross(s),u=s.cross(a);n=u.toLatLonS()}else{var l=this.distanceTo(t),c=this.distanceTo(e);n=l=0&&c>=0,f=n.dot(r)>=0&&n.dot(i)>=0;return h&&f},o.prototype.enclosedBy=function(t){var e=t[0].equals(t[t.length-1]);e||t.push(t[0]);for(var n=t.length-1,r=this.toVector(),i=[],o=0;oMath.PI;return e||t.pop(),a},o.areaOf=function(t,e){var n=void 0==e?6371e3:Number(e),r=t[0].equals(t[t.length-1]);r||t.push(t[0]);for(var i=t.length-1,o=[],s=0;s0?1:-1}),t.exports&&(t.exports=o,t.exports.Vector3d=r)},ae6f:function(t,e){function n(t){switch(t&&t.type||null){case\\\"FeatureCollection\\\":return t.features=t.features.reduce(function(t,e){return t.concat(n(e))},[]),t;case\\\"Feature\\\":return t.geometry?n(t.geometry).map(function(e){return{type:\\\"Feature\\\",properties:JSON.parse(JSON.stringify(t.properties)),geometry:e}}):t;case\\\"MultiPoint\\\":return t.coordinates.map(function(t){return{type:\\\"Point\\\",coordinates:t}});case\\\"MultiPolygon\\\":return t.coordinates.map(function(t){return{type:\\\"Polygon\\\",coordinates:t}});case\\\"MultiLineString\\\":return t.coordinates.map(function(t){return{type:\\\"LineString\\\",coordinates:t}});case\\\"GeometryCollection\\\":return t.geometries.map(n).reduce(function(t,e){return t.concat(e)},[]);case\\\"Point\\\":case\\\"Polygon\\\":case\\\"LineString\\\":return[t]}}t.exports=n},aeff:function(t,e,n){var r=n(\\\"8f76\\\"),i=n(\\\"feb7\\\").point,o=n(\\\"aa1a\\\"),s=n(\\\"61ea\\\");t.exports=function(t,e,n){var a;if(\\\"Feature\\\"===t.type)a=t.geometry.coordinates;else{if(\\\"LineString\\\"!==t.type)throw new Error(\\\"input must be a LineString Feature or Geometry\\\");a=t.coordinates}for(var u=0,l=0;l=u&&l===a.length-1)break;if(u>=e){var c=e-u;if(c){var h=o(a[l],a[l-1])-180,f=s(a[l],c,h,n);return f}return i(a[l])}u+=r(a[l],a[l+1],n)}return i(a[a.length-1])}},b076:function(t,e,n){var r=n(\\\"feb7\\\").featureCollection;function i(t,e){var n,r,i=t.slice(0),o=t.length,s=o-e;while(o-- >s)r=Math.floor((o+1)*Math.random()),n=i[r],i[r]=i[o],i[o]=n;return i.slice(s)}t.exports=function(t,e){var n=r(i(t.features,e));return n}},b07d:function(t,e,n){var r,i;\\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* @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(function(n,o){r=[],i=function(){return{isoBands:o()}}.apply(e,r),void 0===i||(t.exports=i)})(0,function(){var t={successCallback:null,verbose:!1,polygons:!1},e={};function n(n,r,i,o){o=o||{};for(var s=Object.keys(t),a=0;a-1}function _t(t,e,n){for(var r=t.length-1,i=t[0].length-1,o={rows:r,cols:i,cells:[]},s=e+Math.abs(n),a=0;as?128:64,l|=hs?32:16,l|=fs?8:4,l|=gs?2:1;var d=+l,p=0;if(17===l||18===l||33===l||34===l||38===l||68===l||72===l||98===l||102===l||132===l||136===l||137===l||152===l||153===l){var v=(c+h+f+g)/4;p=v>s?2:v0?(l=156,p=4):l=152:33===l?p>0?(l=139,p=4):l=137:72===l?p>0?(l=99,p=4):l=98:132===l&&(p>0?(l=39,p=4):l=38)}if(0!=l&&170!=l){var y,m,x,E,w,b,I,N;y=m=x=E=w=b=I=N=.5;var C=[];1===l?(x=1-St(e,f,g),N=1-St(e,c,g),C.push(Et[l])):169===l?(x=St(s,g,f),N=St(s,g,c),C.push(Et[l])):4===l?(b=1-St(e,h,f),E=St(e,g,f),C.push(mt[l])):166===l?(b=St(s,f,h),E=1-St(s,f,g),C.push(mt[l])):16===l?(w=St(e,f,h),m=St(e,c,h),C.push(yt[l])):154===l?(w=1-St(s,h,f),m=1-St(s,h,c),C.push(yt[l])):64===l?(I=St(e,g,c),y=1-St(e,h,c),C.push(bt[l])):106===l?(I=1-St(s,c,g),y=St(s,c,h),C.push(bt[l])):168===l?(E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),C.push(xt[l]),C.push(Et[l])):2===l?(E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),C.push(xt[l]),C.push(Et[l])):162===l?(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),C.push(xt[l]),C.push(Et[l])):8===l?(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),C.push(yt[l]),C.push(mt[l])):138===l?(w=1-St(e,h,f),b=1-St(s,h,f),y=1-St(s,h,c),m=1-St(e,h,c),C.push(yt[l]),C.push(mt[l])):32===l?(w=St(s,f,h),b=St(e,f,h),y=St(e,c,h),m=St(s,c,h),C.push(yt[l]),C.push(mt[l])):42===l?(N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h),C.push(wt[l]),C.push(bt[l])):128===l&&(N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c),C.push(wt[l]),C.push(bt[l])),5===l?(b=1-St(e,h,f),N=1-St(e,c,g),C.push(mt[l])):165===l?(b=St(s,f,h),N=St(s,g,c),C.push(mt[l])):20===l?(E=St(e,g,f),m=St(e,c,h),C.push(xt[l])):150===l?(E=1-St(s,f,g),m=1-St(s,h,c),C.push(xt[l])):80===l?(w=St(e,f,h),I=St(e,g,c),C.push(yt[l])):90===l?(w=1-St(s,h,f),I=1-St(s,c,g),C.push(yt[l])):65===l?(x=1-St(e,f,g),y=1-St(e,h,c),C.push(Et[l])):105===l?(x=St(s,g,f),y=St(s,c,h),C.push(Et[l])):160===l?(w=St(s,f,h),b=St(e,f,h),N=St(e,g,c),I=St(s,g,c),C.push(yt[l]),C.push(mt[l])):10===l?(w=1-St(e,h,f),b=1-St(s,h,f),N=1-St(s,c,g),I=1-St(e,c,g),C.push(yt[l]),C.push(mt[l])):130===l?(E=1-St(e,f,g),x=1-St(s,f,g),y=1-St(s,h,c),m=1-St(e,h,c),C.push(xt[l]),C.push(Et[l])):40===l?(E=St(s,g,f),x=St(e,g,f),y=St(e,c,h),m=St(s,c,h),C.push(xt[l]),C.push(Et[l])):101===l?(b=St(s,f,h),y=St(s,c,h),C.push(mt[l])):69===l?(b=1-St(e,h,f),y=1-St(e,h,c),C.push(mt[l])):149===l?(N=St(s,g,c),m=1-St(s,h,c),C.push(wt[l])):21===l?(N=1-St(e,c,g),m=St(e,c,h),C.push(wt[l])):86===l?(E=1-St(s,f,g),I=1-St(s,c,g),C.push(xt[l])):84===l?(E=St(e,g,f),I=St(e,g,c),C.push(xt[l])):89===l?(w=1-St(s,h,f),x=St(s,g,f),C.push(Et[l])):81===l?(w=St(e,f,h),x=1-St(e,f,g),C.push(Et[l])):96===l?(w=St(s,f,h),b=St(e,f,h),I=St(e,g,c),y=St(s,c,h),C.push(yt[l]),C.push(mt[l])):74===l?(w=1-St(e,h,f),b=1-St(s,h,f),I=1-St(s,c,g),y=1-St(e,h,c),C.push(yt[l]),C.push(mt[l])):24===l?(w=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),m=St(e,c,h),C.push(yt[l]),C.push(Et[l])):146===l?(w=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),m=1-St(s,h,c),C.push(yt[l]),C.push(Et[l])):6===l?(b=1-St(e,h,f),E=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),C.push(mt[l]),C.push(xt[l])):164===l?(b=St(s,f,h),E=St(e,g,f),N=St(e,g,c),I=St(s,g,c),C.push(mt[l]),C.push(xt[l])):129===l?(x=1-St(e,f,g),N=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c),C.push(Et[l]),C.push(wt[l])):41===l?(x=St(s,g,f),N=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h),C.push(Et[l]),C.push(wt[l])):66===l?(E=1-St(e,f,g),x=1-St(s,f,g),I=1-St(s,c,g),y=1-St(e,h,c),C.push(xt[l]),C.push(Et[l])):104===l?(E=St(s,g,f),x=St(e,g,f),I=St(e,g,c),y=St(s,c,h),C.push(Et[l]),C.push(It[l])):144===l?(w=St(e,f,h),N=St(e,g,c),I=St(s,g,c),m=1-St(s,h,c),C.push(yt[l]),C.push(bt[l])):26===l?(w=1-St(s,h,f),N=1-St(s,c,g),I=1-St(e,c,g),m=St(e,c,h),C.push(yt[l]),C.push(bt[l])):36===l?(b=St(s,f,h),E=St(e,g,f),y=St(e,c,h),m=St(s,c,h),C.push(mt[l]),C.push(xt[l])):134===l?(b=1-St(e,h,f),E=1-St(s,f,g),y=1-St(s,h,c),m=1-St(e,h,c),C.push(mt[l]),C.push(xt[l])):9===l?(w=1-St(e,h,f),b=1-St(s,h,f),x=St(s,g,f),N=1-St(e,c,g),C.push(yt[l]),C.push(mt[l])):161===l?(w=St(s,f,h),b=St(e,f,h),x=1-St(e,f,g),N=St(s,g,c),C.push(yt[l]),C.push(mt[l])):37===l?(b=St(s,f,h),N=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h),C.push(mt[l]),C.push(wt[l])):133===l?(b=1-St(e,h,f),N=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c),C.push(mt[l]),C.push(wt[l])):148===l?(E=St(e,g,f),N=St(e,g,c),I=St(s,g,c),m=1-St(s,h,c),C.push(xt[l]),C.push(bt[l])):22===l?(E=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),m=St(e,c,h),C.push(xt[l]),C.push(bt[l])):82===l?(w=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),I=1-St(s,c,g),C.push(yt[l]),C.push(Et[l])):88===l?(w=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),I=St(e,g,c),C.push(yt[l]),C.push(Et[l])):73===l?(w=1-St(e,h,f),b=1-St(s,h,f),x=St(s,g,f),y=1-St(e,h,c),C.push(yt[l]),C.push(mt[l])):97===l?(w=St(s,f,h),b=St(e,f,h),x=1-St(e,f,g),y=St(s,c,h),C.push(yt[l]),C.push(mt[l])):145===l?(w=St(e,f,h),x=1-St(e,f,g),N=St(s,g,c),m=1-St(s,h,c),C.push(yt[l]),C.push(wt[l])):25===l?(w=1-St(s,h,f),x=St(s,g,f),N=1-St(e,c,g),m=St(e,c,h),C.push(yt[l]),C.push(wt[l])):70===l?(b=1-St(e,h,f),E=1-St(s,f,g),I=1-St(s,c,g),y=1-St(e,h,c),C.push(mt[l]),C.push(xt[l])):100===l?(b=St(s,f,h),E=St(e,g,f),I=St(e,g,c),y=St(s,c,h),C.push(mt[l]),C.push(xt[l])):34===l?(0===p?(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)):(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)),C.push(yt[l]),C.push(mt[l]),C.push(wt[l]),C.push(bt[l])):35===l?(4===p?(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)):(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)),C.push(yt[l]),C.push(mt[l]),C.push(Et[l]),C.push(bt[l])):136===l?(0===p?(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)):(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)),C.push(yt[l]),C.push(mt[l]),C.push(wt[l]),C.push(bt[l])):153===l?(0===p?(w=St(e,f,h),x=1-St(e,f,g),N=1-St(e,c,g),m=St(e,c,h)):(w=1-St(s,h,f),x=St(s,g,f),N=St(s,g,c),m=1-St(s,h,c)),C.push(yt[l]),C.push(Et[l])):102===l?(0===p?(b=1-St(e,h,f),E=St(e,g,f),I=St(e,g,c),y=1-St(e,h,c)):(b=St(s,f,h),E=1-St(s,f,g),I=1-St(s,c,g),y=St(s,c,h)),C.push(mt[l]),C.push(bt[l])):155===l?(4===p?(w=St(e,f,h),x=1-St(e,f,g),N=1-St(e,c,g),m=St(e,c,h)):(w=1-St(s,h,f),x=St(s,g,f),N=St(s,g,c),m=1-St(s,h,c)),C.push(yt[l]),C.push(wt[l])):103===l?(4===p?(b=1-St(e,h,f),E=St(e,g,f),I=St(e,g,c),y=1-St(e,h,c)):(b=St(s,f,h),E=1-St(s,f,g),I=1-St(s,c,g),y=St(s,c,h)),C.push(mt[l]),C.push(xt[l])):152===l?(0===p?(w=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),m=St(e,c,h)):(w=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),m=1-St(s,h,c)),C.push(yt[l]),C.push(xt[l]),C.push(Et[l])):156===l?(4===p?(w=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),m=St(e,c,h)):(w=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),N=St(e,g,c),I=St(s,g,c),m=1-St(s,h,c)),C.push(yt[l]),C.push(Et[l]),C.push(bt[l])):137===l?(0===p?(w=St(s,f,h),b=St(e,f,h),x=1-St(e,f,g),N=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)):(w=1-St(e,h,f),b=1-St(s,h,f),x=St(s,g,f),N=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)),C.push(yt[l]),C.push(mt[l]),C.push(Et[l])):139===l?(4===p?(w=St(s,f,h),b=St(e,f,h),x=1-St(e,f,g),N=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)):(w=1-St(e,h,f),b=1-St(s,h,f),x=St(s,g,f),N=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)),C.push(yt[l]),C.push(mt[l]),C.push(wt[l])):98===l?(0===p?(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),I=St(e,g,c),y=1-St(e,h,c)):(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),I=1-St(s,c,g),y=St(s,c,h)),C.push(yt[l]),C.push(mt[l]),C.push(bt[l])):99===l?(4===p?(w=1-St(e,h,f),b=1-St(s,h,f),E=St(s,g,f),x=St(e,g,f),I=St(e,g,c),y=1-St(e,h,c)):(w=St(s,f,h),b=St(e,f,h),E=1-St(e,f,g),x=1-St(s,f,g),I=1-St(s,c,g),y=St(s,c,h)),C.push(yt[l]),C.push(mt[l]),C.push(Et[l])):38===l?(0===p?(b=1-St(e,h,f),E=St(e,g,f),N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)):(b=St(s,f,h),E=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)),C.push(mt[l]),C.push(wt[l]),C.push(bt[l])):39===l?(4===p?(b=1-St(e,h,f),E=St(e,g,f),N=St(e,g,c),I=St(s,g,c),y=1-St(s,h,c),m=1-St(e,h,c)):(b=St(s,f,h),E=1-St(s,f,g),N=1-St(s,c,g),I=1-St(e,c,g),y=St(e,c,h),m=St(s,c,h)),C.push(mt[l]),C.push(xt[l]),C.push(bt[l])):85===l&&(w=1,b=0,E=1,x=0,N=0,I=1,y=0,m=1),(y<0||y>1||m<0||m>1||w<0||w>1||E<0||E>1||N<0||N>1||I<0||I>1)&&console.log(\\\"MarchingSquaresJS-isoBands: \\\"+l+\\\" \\\"+d+\\\" \\\"+c+\\\",\\\"+h+\\\",\\\"+f+\\\",\\\"+g+\\\" \\\"+p+\\\" \\\"+y+\\\" \\\"+m+\\\" \\\"+w+\\\" \\\"+b+\\\" \\\"+E+\\\" \\\"+x+\\\" \\\"+N+\\\" \\\"+I),o.cells[a][u]={cval:l,cval_real:d,flipped:p,topleft:y,topright:m,righttop:w,rightbottom:b,bottomright:E,bottomleft:x,leftbottom:N,lefttop:I,edges:C}}}}}return o}function Lt(t){for(var e=[],n=t.rows,r=t.cols,i=[],o=0;o0){var a=t.cells[o][s],u=Tt(a),l=null,c=s,h=o;null!==u&&i.push([u.p[0]+c,u.p[1]+h]);do{if(l=Ot(t.cells[h][c],u.x,u.y,u.o),null===l)break;if(i.push([l.p[0]+c,l.p[1]+h]),c+=l.x,h+=l.y,u=l,h<0||h>=n||c<0||c>=r||\\\"undefined\\\"===typeof t.cells[h][c]){c-=l.x,h-=l.y;var f=Pt(t,c,h,l.x,l.y,l.o);if(null===f)break;f.path.forEach(function(t){i.push(t)}),c=f.i,h=f.j,u=f}}while(\\\"undefined\\\"!==typeof t.cells[h][c]&&t.cells[h][c].edges.length>0);e.push(i),i=[],t.cells[o][s].edges.length>0&&s--}return e}function Pt(t,e,n,a,u,l){var c=t.cells[n][e],h=c.cval_real,f=e+a,g=n+u,d=[],p=!1;while(!p){if(\\\"undefined\\\"===typeof t.cells[g]||\\\"undefined\\\"===typeof t.cells[g][f])if(g-=u,f-=a,c=t.cells[g][f],h=c.cval_real,-1===u)if(0===l)if(h&s)d.push([f,g]),a=-1,u=0,l=0;else{if(!(h&o)){d.push([f+c.bottomright,g]),a=0,u=1,l=1,p=!0;break}d.push([f+1,g]),a=1,u=0,l=0}else{if(!(h&s)){if(h&o){d.push([f+c.bottomright,g]),a=0,u=1,l=1,p=!0;break}d.push([f+c.bottomleft,g]),a=0,u=1,l=0,p=!0;break}d.push([f,g]),a=-1,u=0,l=0}else if(1===u)if(0===l){if(!(h&i)){if(h&r){d.push([f+c.topleft,g+1]),a=0,u=-1,l=0,p=!0;break}d.push([f+c.topright,g+1]),a=0,u=-1,l=1,p=!0;break}d.push([f+1,g+1]),a=1,u=0,l=1}else d.push([f+1,g+1]),a=1,u=0,l=1;else if(-1===a)if(0===l){if(!(h&r)){if(h&s){d.push([f,g+c.leftbottom]),a=1,u=0,l=0,p=!0;break}d.push([f,g+c.lefttop]),a=1,u=0,l=1,p=!0;break}d.push([f,g+1]),a=0,u=1,l=0}else{if(!(h&r)){console.log(\\\"MarchingSquaresJS-isoBands: wtf\\\");break}d.push([f,g+1]),a=0,u=1,l=0}else{if(1!==a){console.log(\\\"MarchingSquaresJS-isoBands: we came from nowhere!\\\");break}if(0===l){if(!(h&o)){d.push([f+1,g+c.rightbottom]),a=-1,u=0,l=0,p=!0;break}d.push([f+1,g]),a=0,u=-1,l=1}else{if(!(h&o)){if(h&i){d.push([f+1,g+c.righttop]),a=-1,u=0,l=1;break}d.push([f+1,g+c.rightbottom]),a=-1,u=0,l=0,p=!0;break}d.push([f+1,g]),a=0,u=-1,l=1}}else if(c=t.cells[g][f],h=c.cval_real,-1===a)if(0===l)if(\\\"undefined\\\"!==typeof t.cells[g-1]&&\\\"undefined\\\"!==typeof t.cells[g-1][f])a=0,u=-1,l=1;else{if(!(h&s)){d.push([f+c.bottomright,g]),a=0,u=1,l=1,p=!0;break}d.push([f,g])}else{if(!(h&r)){console.log(\\\"MarchingSquaresJS-isoBands: found entry from top at \\\"+f+\\\",\\\"+g);break}console.log(\\\"MarchingSquaresJS-isoBands: proceeding in x-direction!\\\")}else if(1===a){if(0===l){console.log(\\\"MarchingSquaresJS-isoBands: wtf\\\");break}if(\\\"undefined\\\"!==typeof t.cells[g+1]&&\\\"undefined\\\"!==typeof t.cells[g+1][f])a=0,u=1,l=0;else{if(!(h&i)){d.push([f+c.topleft,g+1]),a=0,u=-1,l=0,p=!0;break}d.push([f+1,g+1]),a=1,u=0,l=1}}else if(-1===u){if(1!==l){console.log(\\\"MarchingSquaresJS-isoBands: wtf\\\");break}if(\\\"undefined\\\"!==typeof t.cells[g][f+1])a=1,u=0,l=1;else{if(!(h&o)){d.push([f+1,g+c.righttop]),a=-1,u=0,l=1,p=!0;break}d.push([f+1,g]),a=0,u=-1,l=1}}else{if(1!==u){console.log(\\\"MarchingSquaresJS-isoBands: where did we came from???\\\");break}if(0!==l){console.log(\\\"MarchingSquaresJS-isoBands: wtf\\\");break}if(\\\"undefined\\\"!==typeof t.cells[g][f-1])a=-1,u=0,l=0;else{if(!(h&r)){d.push([f,g+c.leftbottom]),a=1,u=0,l=0,p=!0;break}d.push([f,g+1]),a=0,u=1,l=0}}if(f+=a,g+=u,f===e&&g===n)break}return{path:d,i:f,j:g,x:a,y:u,o:l}}function Rt(t,e){delete t.edges[e];for(var n=e+1;n0){var e=t.edges[t.edges.length-1],n=t.cval_real;switch(e){case 0:return n&i?{p:[1,t.righttop],x:-1,y:0,o:1}:{p:[t.topleft,1],x:0,y:-1,o:0};case 1:return n&o?{p:[t.topleft,1],x:0,y:-1,o:0}:{p:[1,t.rightbottom],x:-1,y:0,o:0};case 2:return n&o?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[t.topleft,1],x:0,y:-1,o:0};case 3:return n&s?{p:[t.topleft,1],x:0,y:-1,o:0}:{p:[t.bottomleft,0],x:0,y:1,o:0};case 4:return n&i?{p:[1,t.righttop],x:-1,y:0,o:1}:{p:[t.topright,1],x:0,y:-1,o:1};case 5:return n&o?{p:[t.topright,1],x:0,y:-1,o:1}:{p:[1,t.rightbottom],x:-1,y:0,o:0};case 6:return n&o?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[t.topright,1],x:0,y:-1,o:1};case 7:return n&s?{p:[t.topright,1],x:0,y:-1,o:1}:{p:[t.bottomleft,0],x:0,y:1,o:0};case 8:return n&o?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[1,t.righttop],x:-1,y:0,o:1};case 9:return n&s?{p:[1,t.righttop],x:-1,y:0,o:1}:{p:[t.bottomleft,0],x:0,y:1,o:0};case 10:return n&s?{p:[0,t.leftbottom],x:1,y:0,o:0}:{p:[1,t.righttop],x:-1,y:0,o:1};case 11:return n&r?{p:[1,t.righttop],x:-1,y:0,o:1}:{p:[0,t.lefttop],x:1,y:0,o:1};case 12:return n&o?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[1,t.rightbottom],x:-1,y:0,o:0};case 13:return n&s?{p:[1,t.rightbottom],x:-1,y:0,o:0}:{p:[t.bottomleft,0],x:0,y:1,o:0};case 14:return n&s?{p:[0,t.leftbottom],x:1,y:0,o:0}:{p:[1,t.rightbottom],x:-1,y:0,o:0};case 15:return n&r?{p:[1,t.rightbottom],x:-1,y:0,o:0}:{p:[0,t.lefttop],x:1,y:0,o:1};case 16:return n&o?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[0,t.leftbottom],x:1,y:0,o:0};case 17:return n&r?{p:[t.bottomright,0],x:0,y:1,o:1}:{p:[0,t.lefttop],x:1,y:0,o:1};case 18:return n&s?{p:[0,t.leftbottom],x:1,y:0,o:0}:{p:[t.bottomleft,0],x:0,y:1,o:0};case 19:return n&r?{p:[t.bottomleft,0],x:0,y:1,o:0}:{p:[0,t.lefttop],x:1,y:0,o:1};case 20:return n&r?{p:[t.topleft,1],x:0,y:-1,o:0}:{p:[0,t.leftbottom],x:1,y:0,o:0};case 21:return n&i?{p:[0,t.leftbottom],x:1,y:0,o:0}:{p:[t.topright,1],x:0,y:-1,o:1};case 22:return n&r?{p:[t.topleft,1],x:0,y:-1,o:0}:{p:[0,t.lefttop],x:1,y:0,o:1};case 23:return n&i?{p:[0,t.lefttop],x:1,y:0,o:1}:{p:[t.topright,1],x:0,y:-1,o:1};default:console.log(\\\"MarchingSquaresJS-isoBands: edge index out of range!\\\"),console.log(t);break}}return null}function Ot(t,e,n,R){var T,O,A,D,F,k=t.cval;switch(e){case-1:switch(R){case 0:T=mt[k],A=v[k],D=y[k],F=m[k];break;default:T=yt[k],A=g[k],D=d[k],F=p[k];break}break;case 1:switch(R){case 0:T=wt[k],A=_[k],D=L[k],F=P[k];break;default:T=bt[k],A=C[k],D=S[k],F=M[k];break}break;default:switch(n){case-1:switch(R){case 0:T=It[k],A=a[k],D=u[k],F=l[k];break;default:T=Nt[k],A=c[k],D=h[k],F=f[k];break}break;case 1:switch(R){case 0:T=Et[k],A=x[k],D=E[k],F=w[k];break;default:T=xt[k],A=b[k],D=I[k],F=N[k];break}break;default:break}break}if(O=t.edges.indexOf(T),\\\"undefined\\\"===typeof t.edges[O])return null;switch(Rt(t,O),k=t.cval_real,T){case 0:k&i?(e=t.topleft,n=1):(e=1,n=t.righttop);break;case 1:k&o?(e=1,n=t.rightbottom):(e=t.topleft,n=1);break;case 2:k&o?(e=t.topleft,n=1):(e=t.bottomright,n=0);break;case 3:k&s?(e=t.bottomleft,n=0):(e=t.topleft,n=1);break;case 4:k&i?(e=t.topright,n=1):(e=1,n=t.righttop);break;case 5:k&o?(e=1,n=t.rightbottom):(e=t.topright,n=1);break;case 6:k&o?(e=t.topright,n=1):(e=t.bottomright,n=0);break;case 7:k&s?(e=t.bottomleft,n=0):(e=t.topright,n=1);break;case 8:k&o?(e=1,n=t.righttop):(e=t.bottomright,n=0);break;case 9:k&s?(e=t.bottomleft,n=0):(e=1,n=t.righttop);break;case 10:k&s?(e=1,n=t.righttop):(e=0,n=t.leftbottom);break;case 11:k&r?(e=0,n=t.lefttop):(e=1,n=t.righttop);break;case 12:k&o?(e=1,n=t.rightbottom):(e=t.bottomright,n=0);break;case 13:k&s?(e=t.bottomleft,n=0):(e=1,n=t.rightbottom);break;case 14:k&s?(e=1,n=t.rightbottom):(e=0,n=t.leftbottom);break;case 15:k&r?(e=0,n=t.lefttop):(e=1,n=t.rightbottom);break;case 16:k&o?(e=0,n=t.leftbottom):(e=t.bottomright,n=0);break;case 17:k&r?(e=0,n=t.lefttop):(e=t.bottomright,n=0);break;case 18:k&s?(e=t.bottomleft,n=0):(e=0,n=t.leftbottom);break;case 19:k&r?(e=0,n=t.lefttop):(e=t.bottomleft,n=0);break;case 20:k&r?(e=0,n=t.leftbottom):(e=t.topleft,n=1);break;case 21:k&i?(e=t.topright,n=1):(e=0,n=t.leftbottom);break;case 22:k&r?(e=0,n=t.lefttop):(e=t.topleft,n=1);break;case 23:k&i?(e=t.topright,n=1):(e=0,n=t.lefttop);break;default:return console.log(\\\"MarchingSquaresJS-isoBands: edge index out of range!\\\"),console.log(t),null}return\\\"undefined\\\"!==typeof e&&\\\"undefined\\\"!==typeof n&&\\\"undefined\\\"!==typeof A&&\\\"undefined\\\"!==typeof D&&\\\"undefined\\\"!==typeof F||(console.log(\\\"MarchingSquaresJS-isoBands: undefined value!\\\"),console.log(t),console.log(e+\\\" \\\"+n+\\\" \\\"+A+\\\" \\\"+D+\\\" \\\"+F)),{p:[e,n],x:A,y:D,o:F}}function At(t){var e=[],n=0;return t.cells.forEach(function(t,r){t.forEach(function(t,i){if(\\\"undefined\\\"!==typeof t){var o=Ct[t.cval](t);\\\"object\\\"===typeof o&&Mt(o)?\\\"object\\\"===typeof o[0]&&Mt(o[0])?\\\"object\\\"===typeof o[0][0]&&Mt(o[0][0])?o.forEach(function(t){t.forEach(function(t){t[0]+=i,t[1]+=r}),e[n++]=t}):(o.forEach(function(t){t[0]+=i,t[1]+=r}),e[n++]=o):console.log(\\\"MarchingSquaresJS-isoBands: bandcell polygon with malformed coordinates\\\"):console.log(\\\"MarchingSquaresJS-isoBands: bandcell polygon with null coordinates\\\")}})}),e}return Ct[1]=Ct[169]=R,Ct[4]=Ct[166]=T,Ct[16]=Ct[154]=O,Ct[64]=Ct[106]=A,Ct[168]=Ct[2]=D,Ct[162]=Ct[8]=F,Ct[138]=Ct[32]=k,Ct[42]=Ct[128]=G,Ct[5]=Ct[165]=V,Ct[20]=Ct[150]=q,Ct[80]=Ct[90]=B,Ct[65]=Ct[105]=z,Ct[160]=Ct[10]=j,Ct[130]=Ct[40]=U,Ct[85]=X,Ct[101]=Ct[69]=Y,Ct[149]=Ct[21]=W,Ct[86]=Ct[84]=H,Ct[89]=Ct[81]=J,Ct[96]=Ct[74]=Z,Ct[24]=Ct[146]=K,Ct[6]=Ct[164]=$,Ct[129]=Ct[41]=Q,Ct[66]=Ct[104]=tt,Ct[144]=Ct[26]=et,Ct[36]=Ct[134]=nt,Ct[9]=Ct[161]=rt,Ct[37]=Ct[133]=it,Ct[148]=Ct[22]=ot,Ct[82]=Ct[88]=st,Ct[73]=Ct[97]=at,Ct[145]=Ct[25]=ut,Ct[70]=Ct[100]=lt,Ct[34]=function(t){return[G(t),F(t)]},Ct[35]=ct,Ct[136]=function(t){return[k(t),D(t)]},Ct[153]=function(t){return[O(t),R(t)]},Ct[102]=function(t){return[T(t),A(t)]},Ct[155]=ht,Ct[103]=ft,Ct[152]=function(t){return[O(t),D(t)]},Ct[156]=gt,Ct[137]=function(t){return[k(t),R(t)]},Ct[139]=dt,Ct[98]=function(t){return[F(t),A(t)]},Ct[99]=pt,Ct[38]=function(t){return[T(t),G(t)]},Ct[39]=vt,n})},b0a3:function(t,e,n){var r=n(\\\"feb7\\\").polygon,i=n(\\\"5664\\\");function o(t){var e=s(t),n=2,o=i(e.vertices,e.holes,n),a=[],u=[];o.forEach(function(t,r){var i=o[r];u.push([e.vertices[i*n],e.vertices[i*n+1]])});for(var l=0;l0&&(r+=t[i-1].length,n.holes.push(r))}return n}t.exports=function(t){if(!t.geometry||\\\"Polygon\\\"!==t.geometry.type&&\\\"MultiPolygon\\\"!==t.geometry.type)throw new Error(\\\"input must be a Polygon or MultiPolygon\\\");var e={type:\\\"FeatureCollection\\\",features:[]};return\\\"Polygon\\\"===t.geometry.type?e.features=o(t.geometry.coordinates):t.geometry.coordinates.forEach(function(t){e.features=e.features.concat(o(t))}),e}},b24d:function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"6991\\\"),o=n(\\\"feb7\\\"),s=n(\\\"00a2\\\").getCoords,a=n(\\\"fa64\\\"),u=o.point,l=r.featureEach,c=o.featureCollection;function h(t,e){var n=s(t),r=s(e);if(2!==n.length)throw new Error(\\\" line1 must only contain 2 coordinates\\\");if(2!==r.length)throw new Error(\\\" line2 must only contain 2 coordinates\\\");var i=n[0][0],o=n[0][1],a=n[1][0],l=n[1][1],c=r[0][0],h=r[0][1],f=r[1][0],g=r[1][1],d=(g-h)*(a-i)-(f-c)*(l-o),p=(f-c)*(o-h)-(g-h)*(i-c),v=(a-i)*(o-h)-(l-o)*(i-c);if(0===d)return null;var y=p/d,m=v/d;if(y>=0&&y<=1&&m>=0&&m<=1){var x=i+y*(a-i),E=o+y*(l-o);return u([x,E])}return null}t.exports=function(t,e){var n={},r=[];if(\\\"LineString\\\"===t.type&&(t=o.feature(t)),\\\"LineString\\\"===e.type&&(e=o.feature(e)),\\\"Feature\\\"===t.type&&\\\"Feature\\\"===e.type&&\\\"LineString\\\"===t.geometry.type&&\\\"LineString\\\"===e.geometry.type&&2===t.geometry.coordinates.length&&2===e.geometry.coordinates.length){var u=h(t,e);return u&&r.push(u),c(r)}var f=i();return f.load(a(e)),l(a(t),function(t){l(f.search(t),function(e){var i=h(t,e);if(i){var o=s(i).join(\\\",\\\");n[o]||(n[o]=!0,r.push(i))}})}),c(r)}},b3f3:function(t,e){function n(t){if(!t)throw new Error(\\\"No obj passed\\\");var e=r(t);if(e.length>1&&\\\"number\\\"===typeof e[0]&&\\\"number\\\"===typeof e[1])return e;throw new Error(\\\"Coordinate is not a valid Point\\\")}function r(t){if(!t)throw new Error(\\\"No obj passed\\\");var e;if(t.length?e=t:t.coordinates?e=t.coordinates:t.geometry&&t.geometry.coordinates&&(e=t.geometry.coordinates),e)return i(e),e;throw new Error(\\\"No valid coordinates\\\")}function i(t){if(t.length>1&&\\\"number\\\"===typeof t[0]&&\\\"number\\\"===typeof t[1])return!0;if(t[0].length)return i(t[0]);throw new Error(\\\"coordinates must only contain numbers\\\")}function o(t,e,n){if(!e||!n)throw new Error(\\\"type and name required\\\");if(!t||t.type!==e)throw new Error(\\\"Invalid input to \\\"+n+\\\": must be a \\\"+e+\\\", given \\\"+t.type)}function s(t,e,n){if(!t)throw new Error(\\\"No feature passed\\\");if(!n)throw new Error(\\\".featureOf() requires a name\\\");if(!t||\\\"Feature\\\"!==t.type||!t.geometry)throw new Error(\\\"Invalid input to \\\"+n+\\\", Feature with geometry required\\\");if(!t.geometry||t.geometry.type!==e)throw new Error(\\\"Invalid input to \\\"+n+\\\": must be a \\\"+e+\\\", given \\\"+t.geometry.type)}function a(t,e,n){if(!t)throw new Error(\\\"No featureCollection passed\\\");if(!n)throw new Error(\\\".collectionOf() requires a name\\\");if(!t||\\\"FeatureCollection\\\"!==t.type)throw new Error(\\\"Invalid input to \\\"+n+\\\", FeatureCollection required\\\");for(var r=0;r0}},b801:function(t,e,n){\\\"use strict\\\";var r=Math.PI/180,i=180/Math.PI,o=function(t,e){this.lon=t,this.lat=e,this.x=r*t,this.y=r*e};o.prototype.view=function(){return String(this.lon).slice(0,4)+\\\",\\\"+String(this.lat).slice(0,4)},o.prototype.antipode=function(){var t=-1*this.lat,e=this.lon<0?180+this.lon:-1*(180-this.lon);return new o(e,t)};var s=function(){this.coords=[],this.length=0};s.prototype.move_to=function(t){this.length++,this.coords.push(t)};var a=function(t){this.properties=t||{},this.geometries=[]};a.prototype.json=function(){if(this.geometries.length<=0)return{geometry:{type:\\\"LineString\\\",coordinates:null},type:\\\"Feature\\\",properties:this.properties};if(1===this.geometries.length)return{geometry:{type:\\\"LineString\\\",coordinates:this.geometries[0].coords},type:\\\"Feature\\\",properties:this.properties};for(var t=[],e=0;ed&&(y>f&&vf&&yc&&(c=m)}var x=[];if(l&&c0&&Math.abs(b-n[w-1][0])>d){var I=parseFloat(n[w-1][0]),N=parseFloat(n[w-1][1]),C=parseFloat(n[w][0]),S=parseFloat(n[w][1]);if(I>-180&&I-180&&n[w-1][0]f&&I<180&&-180===C&&w+1f&&n[w-1][0]<180){E.push([180,n[w][1]]),w++,E.push([n[w][0],n[w][1]]);continue}if(If){var M=I;I=C,C=M;var _=N;N=S,S=_}if(I>f&&C=180&&If?180:-180,P]),E=[],E.push([n[w-1][0]>f?-180:180,P]),x.push(E)}else E=[],x.push(E);E.push([b,n[w][1]])}else E.push([n[w][0],n[w][1]])}}else{var R=[];x.push(R);for(var T=0;T=0))throw new Error(\\\"precision must be a positive number\\\");var n=Math.pow(10,e||0);return Math.round(t*n)/n}function p(t,e){if(void 0===t||null===t)throw new Error(\\\"radians is required\\\");var n=f[e||\\\"kilometers\\\"];if(!n)throw new Error(\\\"units is invalid\\\");return t*n}function v(t,e){if(void 0===t||null===t)throw new Error(\\\"distance is required\\\");var n=f[e||\\\"kilometers\\\"];if(!n)throw new Error(\\\"units is invalid\\\");return t/n}function y(t,e){return x(v(t,e))}function m(t){if(null===t||void 0===t)throw new Error(\\\"bearing is required\\\");var e=t%360;return e<0&&(e+=360),e}function x(t){if(null===t||void 0===t)throw new Error(\\\"radians is required\\\");var e=t%(2*Math.PI);return 180*e/Math.PI}function E(t){if(null===t||void 0===t)throw new Error(\\\"degrees is required\\\");var e=t%360;return e*Math.PI/180}function w(t,e,n){if(null===t||void 0===t)throw new Error(\\\"distance is required\\\");if(!(t>=0))throw new Error(\\\"distance must be a positive number\\\");var r=p(v(t,e),n||\\\"kilometers\\\");return r}function b(t,e,n){if(null===t||void 0===t)throw new Error(\\\"area is required\\\");if(!(t>=0))throw new Error(\\\"area must be a positive number\\\");var r=g[e||\\\"meters\\\"];if(!r)throw new Error(\\\"invalid original units\\\");var i=g[n||\\\"kilometers\\\"];if(!i)throw new Error(\\\"invalid final units\\\");return t/r*i}function I(t){return!isNaN(t)&&null!==t&&!Array.isArray(t)}t.exports={feature:n,geometry:r,featureCollection:a,geometryCollection:h,point:i,multiPoint:l,lineString:s,multiLineString:u,polygon:o,multiPolygon:c,radiansToDistance:p,distanceToRadians:v,distanceToDegrees:y,radians2degrees:x,degrees2radians:E,bearingToAngle:m,convertDistance:w,convertArea:b,round:d,isNumber:I}},bb10:function(t,e,n){var r=n(\\\"61ea\\\"),i=n(\\\"32ef\\\"),o=n(\\\"feb7\\\").lineString;function s(t){var e=t%360;return e<0&&(e+=360),e}t.exports=function(t,e,n,a,u,l){if(!t)throw new Error(\\\"center is required\\\");if(void 0===n||null===n)throw new Error(\\\"bearing1 is required\\\");if(void 0===a||null===a)throw new Error(\\\"bearing2 is required\\\");if(!e)throw new Error(\\\"radius is required\\\");u=u||64;var c=s(n),h=s(a),f=t.properties;if(c===h)return o(i(t,e,u,l).geometry.coordinates[0],f);var g=c,d=cd&&v.push(r(t,e,d,l).geometry.coordinates),o(v,f)}},bc3a:function(t,e,n){t.exports=n(\\\"cee4\\\")},bd8d:function(t,e,n){var r=n(\\\"8678\\\");t.exports=function(t,e,n,i){return t=JSON.parse(JSON.stringify(t)),e=JSON.parse(JSON.stringify(e)),t.features.forEach(function(t){t.properties||(t.properties={}),e.features.forEach(function(e){if(void 0===t.properties[i]){var o=r(t,e);o&&(t.properties[i]=e.properties[n])}})}),t}},be13:function(t,e){t.exports=function(t){if(void 0==t)throw TypeError(\\\"Can't call method on \\\"+t);return t}},c01c:function(t,e,n){\\\"use strict\\\";t.exports=i;var r=+(Math.pow(2,27)+1);function i(t,e,n){var i=t*e,o=r*t,s=o-t,a=o-s,u=t-a,l=r*e,c=l-e,h=l-c,f=e-h,g=i-a*h,d=g-u*h,p=d-a*f,v=u*f-p;return n?(n[0]=v,n[1]=i,n):[v,i]}},c226:function(t,e,n){\\\"use strict\\\";var r={parseDMS:function(t){if(\\\"number\\\"==typeof t&&isFinite(t))return Number(t);var e,n=String(t).trim().replace(/^-/,\\\"\\\").replace(/[NSEW]$/i,\\\"\\\").split(/[^0-9.,]+/);if(\\\"\\\"==n[n.length-1]&&n.splice(n.length-1),\\\"\\\"==n)return NaN;switch(n.length){case 3:e=n[0]/1+n[1]/60+n[2]/3600;break;case 2:e=n[0]/1+n[1]/60;break;case 1:e=n[0];break;default:return NaN}return/^-|[WS]$/i.test(t.trim())&&(e=-e),Number(e)},separator:\\\"\\\",toDMS:function(t,e,n){if(isNaN(t))return null;if(void 0===e&&(e=\\\"dms\\\"),void 0===n)switch(e){case\\\"d\\\":case\\\"deg\\\":n=4;break;case\\\"dm\\\":case\\\"deg+min\\\":n=2;break;case\\\"dms\\\":case\\\"deg+min+sec\\\":n=0;break;default:e=\\\"dms\\\",n=0}var i,o,s,a;switch(t=Math.abs(t),e){default:case\\\"d\\\":case\\\"deg\\\":o=t.toFixed(n),o<100&&(o=\\\"0\\\"+o),o<10&&(o=\\\"0\\\"+o),i=o+\\\"°\\\";break;case\\\"dm\\\":case\\\"deg+min\\\":o=Math.floor(t),s=(60*t%60).toFixed(n),60==s&&(s=0,o++),o=(\\\"000\\\"+o).slice(-3),s<10&&(s=\\\"0\\\"+s),i=o+\\\"°\\\"+r.separator+s+\\\"′\\\";break;case\\\"dms\\\":case\\\"deg+min+sec\\\":o=Math.floor(t),s=Math.floor(3600*t/60)%60,a=(3600*t%60).toFixed(n),60==a&&(a=(0).toFixed(n),s++),60==s&&(s=0,o++),o=(\\\"000\\\"+o).slice(-3),s=(\\\"00\\\"+s).slice(-2),a<10&&(a=\\\"0\\\"+a),i=o+\\\"°\\\"+r.separator+s+\\\"′\\\"+r.separator+a+\\\"″\\\";break}return i},toLat:function(t,e,n){var i=r.toDMS(t,e,n);return null===i?\\\"–\\\":i.slice(1)+r.separator+(t<0?\\\"S\\\":\\\"N\\\")},toLon:function(t,e,n){var i=r.toDMS(t,e,n);return null===i?\\\"–\\\":i+r.separator+(t<0?\\\"W\\\":\\\"E\\\")},toBrng:function(t,e,n){t=(Number(t)+360)%360;var i=r.toDMS(t,e,n);return null===i?\\\"–\\\":i.replace(\\\"360\\\",\\\"0\\\")},compassPoint:function(t,e){void 0===e&&(e=3),t=(t%360+360)%360;var n=[\\\"N\\\",\\\"NNE\\\",\\\"NE\\\",\\\"ENE\\\",\\\"E\\\",\\\"ESE\\\",\\\"SE\\\",\\\"SSE\\\",\\\"S\\\",\\\"SSW\\\",\\\"SW\\\",\\\"WSW\\\",\\\"W\\\",\\\"WNW\\\",\\\"NW\\\",\\\"NNW\\\"],r=4*Math.pow(2,e-1),i=n[Math.round(t*r/360)%r*16/r];return i}};t.exports&&(t.exports=r)},c29c:function(t,e){function n(t){return t[0].toString()+\\\",\\\"+t[1].toString()}function r(t,e){var r,i=n(t.coordinates[0]),o=n(t.coordinates[t.coordinates.length-1]),s=n(e.coordinates[0]),a=n(e.coordinates[e.coordinates.length-1]);if(i===a)r=e.coordinates.concat(t.coordinates.slice(1));else if(s===o)r=t.coordinates.concat(e.coordinates.slice(1));else if(i===s)r=t.coordinates.slice(1).reverse().concat(e.coordinates);else{if(o!==a)return null;r=t.coordinates.concat(e.coordinates.reverse().slice(1))}return{type:\\\"LineString\\\",coordinates:r}}function i(t){var e=t.slice(),n=[];while(e.length>0){var i=e.shift();e=e.reduce(function(t,e){var n=r(i,e);return n?i=n:t.push(e),t},[]),n.push(i)}return n=1===n.length?n[0]:{type:\\\"MultiLineString\\\",coordinates:n.map(function(t){return t.coordinates})},n}t.exports=i},c345:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\"),i=[\\\"age\\\",\\\"authorization\\\",\\\"content-length\\\",\\\"content-type\\\",\\\"etag\\\",\\\"expires\\\",\\\"from\\\",\\\"host\\\",\\\"if-modified-since\\\",\\\"if-unmodified-since\\\",\\\"last-modified\\\",\\\"location\\\",\\\"max-forwards\\\",\\\"proxy-authorization\\\",\\\"referer\\\",\\\"retry-after\\\",\\\"user-agent\\\"];t.exports=function(t){var e,n,o,s={};return t?(r.forEach(t.split(\\\"\\\\n\\\"),function(t){if(o=t.indexOf(\\\":\\\"),e=r.trim(t.substr(0,o)).toLowerCase(),n=r.trim(t.substr(o+1)),e){if(s[e]&&i.indexOf(e)>=0)return;s[e]=\\\"set-cookie\\\"===e?(s[e]?s[e]:[]).concat([n]):s[e]?s[e]+\\\", \\\"+n:n}}),s):s}},c366:function(t,e,n){var r=n(\\\"6821\\\"),i=n(\\\"9def\\\"),o=n(\\\"77f1\\\");t.exports=function(t){return function(e,n,s){var a,u=r(e),l=i(u.length),c=o(s,l);if(t&&n!=n){while(l>c)if(a=u[c++],a!=a)return!0}else for(;l>c;c++)if((t||c in u)&&u[c]===n)return t||c||0;return!t&&-1}}},c401:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\");t.exports=function(t,e,n){return r.forEach(n,function(n){t=n(t,e)}),t}},c532:function(t,e,n){\\\"use strict\\\";var r=n(\\\"1d2b\\\"),i=n(\\\"c7ce\\\"),o=Object.prototype.toString;function s(t){return\\\"[object Array]\\\"===o.call(t)}function a(t){return\\\"[object ArrayBuffer]\\\"===o.call(t)}function u(t){return\\\"undefined\\\"!==typeof FormData&&t instanceof FormData}function l(t){var e;return e=\\\"undefined\\\"!==typeof ArrayBuffer&&ArrayBuffer.isView?ArrayBuffer.isView(t):t&&t.buffer&&t.buffer instanceof ArrayBuffer,e}function c(t){return\\\"string\\\"===typeof t}function h(t){return\\\"number\\\"===typeof t}function f(t){return\\\"undefined\\\"===typeof t}function g(t){return null!==t&&\\\"object\\\"===typeof t}function d(t){return\\\"[object Date]\\\"===o.call(t)}function p(t){return\\\"[object File]\\\"===o.call(t)}function v(t){return\\\"[object Blob]\\\"===o.call(t)}function y(t){return\\\"[object Function]\\\"===o.call(t)}function m(t){return g(t)&&y(t.pipe)}function x(t){return\\\"undefined\\\"!==typeof URLSearchParams&&t instanceof URLSearchParams}function E(t){return t.replace(/^\\\\s*/,\\\"\\\").replace(/\\\\s*$/,\\\"\\\")}function w(){return(\\\"undefined\\\"===typeof navigator||\\\"ReactNative\\\"!==navigator.product&&\\\"NativeScript\\\"!==navigator.product&&\\\"NS\\\"!==navigator.product)&&(\\\"undefined\\\"!==typeof window&&\\\"undefined\\\"!==typeof document)}function b(t,e){if(null!==t&&\\\"undefined\\\"!==typeof t)if(\\\"object\\\"!==typeof t&&(t=[t]),s(t))for(var n=0,r=t.length;nd?(g.unshift(t),d=e):g.push(t)}else g.push(t)}),s(g,e);default:throw new Error(\\\"geometry type \\\"+l+\\\" is not supported\\\")}}function c(t){return t.geometry?t.geometry.type:t.type}function h(t){var e=t[0],n=e[0],r=e[1],i=t[t.length-1],o=i[0],s=i[1];return n===o&&r===s||t.push(e),t}function f(t){var e=t[0],n=t[1],r=t[2],i=t[3];return Math.abs(e-r)*Math.abs(n-i)}t.exports=function(t,e,n,r){if(!t)throw new Error(\\\"lines is required\\\");n=void 0===n||n,r=void 0===r||r;var o=c(t);switch(o){case\\\"FeatureCollection\\\":case\\\"GeometryCollection\\\":var s=[],u=t.features?t.features:t.geometries;return u.forEach(function(t){s.push(i(l(t,{},n,r)))}),a(s,e)}return l(t,e,n,r)}},c69a:function(t,e,n){t.exports=!n(\\\"9e1e\\\")&&!n(\\\"79e5\\\")(function(){return 7!=Object.defineProperty(n(\\\"230e\\\")(\\\"div\\\"),\\\"a\\\",{get:function(){return 7}}).a})},c712:function(t,e,n){\\\"use strict\\\";var r=n(\\\"04b9\\\"),i=n(\\\"4485\\\"),o=n(\\\"feb7\\\"),s=o.featureCollection;t.exports=function(t){var e=r.fromGeoJson(t);e.deleteDangles(),e.deleteCutEdges();var n=[],o=[];return e.getEdgeRings().filter(function(t){return t.isValid()}).forEach(function(t){t.isHole()?n.push(t):o.push(t)}),n.forEach(function(t){i.findEdgeRingContaining(t,o)&&o.push(t)}),s(o.map(function(t){return t.toPolygon()}))}},c71c:function(t,e,n){var r=n(\\\"32ef\\\"),i=n(\\\"716c\\\").coordEach,o=n(\\\"feb7\\\"),s=n(\\\"00a2\\\").getCoords,a=o.polygon,u=n(\\\"bb10\\\");function l(t){var e=t%360;return e<0&&(e+=360),e}t.exports=function(t,e,n,o,c,h){if(!t)throw new Error(\\\"center is required\\\");if(void 0===n||null===n)throw new Error(\\\"bearing1 is required\\\");if(void 0===o||null===o)throw new Error(\\\"bearing2 is required\\\");if(!e)throw new Error(\\\"radius is required\\\");if(c=c||64,l(n)===l(o))return r(t,e,c,h);var f=s(t),g=u(t,e,n,o,c,h),d=[[f]];return i(g,function(t){d[0].push(t)}),d[0].push(f),a(d)}},c7ce:function(t,e){\\n/*!\\n * Determine if an object is a Buffer\\n *\\n * @author Feross Aboukhadijeh \\n * @license MIT\\n */\\nt.exports=function(t){return null!=t&&null!=t.constructor&&\\\"function\\\"===typeof t.constructor.isBuffer&&t.constructor.isBuffer(t)}},c8af:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\");t.exports=function(t,e){r.forEach(t,function(n,r){r!==e&&r.toUpperCase()===e.toUpperCase()&&(t[e]=n,delete t[r])})}},c8ba:function(t,e){var n;n=function(){return this}();try{n=n||new Function(\\\"return this\\\")()}catch(r){\\\"object\\\"===typeof window&&(n=window)}t.exports=n},c9a6:function(t,e,n){\\\"use strict\\\";var r=function(){function t(t,e){for(var n=0;n \\\"+this.to.id+\\\" }\\\"}},{key:\\\"toLineString\\\",value:function(){return s([this.from.coordinates,this.to.coordinates])}},{key:\\\"compareTo\\\",value:function(t){return u(t.from.coordinates,t.to.coordinates,this.to.coordinates)}}]),t}();t.exports=l},ca12:function(t,e,n){var r=n(\\\"eb10\\\"),i=n(\\\"98c6\\\"),o=n(\\\"8a68\\\"),s=n(\\\"945f\\\"),a=n(\\\"de3e\\\"),u=n(\\\"b3f3\\\"),l=n(\\\"202d\\\"),c=n(\\\"404d\\\"),h=s.polygon,f=s.multiPolygon,g=u.collectionOf,d=s.featureCollection;function p(t,e,n){for(var r=[],i=1;i1&&r(t[s[c-2]],t[s[c-1]],l)<=0)c-=1,s.pop();s.push(u),c=a.length;while(c>1&&r(t[a[c-2]],t[a[c-1]],l)>=0)c-=1,a.pop();a.push(u)}n=new Array(a.length+s.length-2);for(var h=0,f=(i=0,s.length);i0;--g)n[h++]=a[g];return n}},ca39:function(t,e,n){\\\"use strict\\\";t.exports=a;var r=n(\\\"0000\\\"),i=n(\\\"7899\\\");function o(t,e){for(var n=t.length,r=new Array(n),i=0;i=e[u]&&(a+=1);o[s]=a}}return t}function a(t,e){try{return r(t,!0)}catch(l){var n=i(t);if(n.length<=e)return[];var a=o(t,n),u=r(a,!0);return s(u,n)}}},ca5a:function(t,e){var n=0,r=Math.random();t.exports=function(t){return\\\"Symbol(\\\".concat(void 0===t?\\\"\\\":t,\\\")_\\\",(++n+r).toString(36))}},cadf:function(t,e,n){\\\"use strict\\\";var r=n(\\\"9c6c\\\"),i=n(\\\"d53b\\\"),o=n(\\\"84f2\\\"),s=n(\\\"6821\\\");t.exports=n(\\\"01f9\\\")(Array,\\\"Array\\\",function(t,e){this._t=s(t),this._i=0,this._k=e},function(){var t=this._t,e=this._k,n=this._i++;return!t||n>=t.length?(this._t=void 0,i(1)):i(0,\\\"keys\\\"==e?n:\\\"values\\\"==e?t[n]:[n,t[n]])},\\\"values\\\"),o.Arguments=o.Array,r(\\\"keys\\\"),r(\\\"values\\\"),r(\\\"entries\\\")},cb7c:function(t,e,n){var r=n(\\\"d3f4\\\");t.exports=function(t){if(!r(t))throw TypeError(t+\\\" is not an object!\\\");return t}},ce10:function(t,e,n){var r=n(\\\"69a8\\\"),i=n(\\\"6821\\\"),o=n(\\\"c366\\\")(!1),s=n(\\\"613b\\\")(\\\"IE_PROTO\\\");t.exports=function(t,e){var n,a=i(t),u=0,l=[];for(n in a)n!=s&&r(a,n)&&l.push(n);while(e.length>u)r(a,n=e[u++])&&(~o(l,n)||l.push(n));return l}},cee4:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\"),i=n(\\\"1d2b\\\"),o=n(\\\"0a06\\\"),s=n(\\\"4a7b\\\"),a=n(\\\"2444\\\");function u(t){var e=new o(t),n=i(o.prototype.request,e);return r.extend(n,o.prototype,e),r.extend(n,e),n}var l=u(a);l.Axios=o,l.create=function(t){return u(s(l.defaults,t))},l.Cancel=n(\\\"7a77\\\"),l.CancelToken=n(\\\"8df4\\\"),l.isCancel=n(\\\"2e67\\\"),l.all=function(t){return Promise.all(t)},l.spread=n(\\\"0df6\\\"),t.exports=l,t.exports.default=l},cfc7:function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"7fae\\\"),o=n(\\\"6991\\\"),s=n(\\\"00a2\\\"),a=n(\\\"fa64\\\"),u=n(\\\"e868\\\"),l=n(\\\"9574\\\"),c=n(\\\"feb7\\\").featureCollection,h=s.getCoords,f=r.featureEach,g=r.segmentEach;function d(t,e){var n=h(e),r=h(t),o=r[0],s=r[r.length-1],a=t.geometry.coordinates;return i(n[0],o)?a.unshift(n[1]):i(n[0],s)?a.push(n[1]):i(n[1],o)?a.unshift(n[0]):i(n[1],s)&&a.push(n[0]),t}t.exports=function(t,e,n){var r=[];n=n||0;var s,p=o();return p.load(a(t)),g(e,function(t){var e=!1;f(p.search(t),function(r){if(!1===e){var o=h(t).sort(),a=h(r).sort();i(o,a)?(e=!0,s=s?d(s,t):t):(0===n?l(o[0],r)&&l(o[1],r):u(r,o[0]).properties.dist<=n&&u(r,o[1]).properties.dist<=n)?(e=!0,s=s?d(s,t):t):(0===n?l(a[0],t)&&l(a[1],t):u(t,a[0]).properties.dist<=n&&u(t,a[1]).properties.dist<=n)&&(s=s?d(s,r):r)}}),!1===e&&s&&(r.push(s),s=void 0)}),s&&r.push(s),c(r)}},d1bd:function(t,e,n){\\\"use strict\\\";function r(t,e,n){var r=t+e,i=r-t,o=r-i,s=e-i,a=t-o;return n?(n[0]=a+s,n[1]=r,n):[a+s,r]}t.exports=r},d2c8:function(t,e,n){var r=n(\\\"aae3\\\"),i=n(\\\"be13\\\");t.exports=function(t,e,n){if(r(e))throw TypeError(\\\"String#\\\"+n+\\\" doesn't accept regex!\\\");return String(i(t))}},d31b:function(t,e,n){var r=n(\\\"feb7\\\"),i=n(\\\"00a2\\\"),o=i.getCoords,s=i.getGeomType;function a(t,e,n){var r={type:e,coordinates:n};return t.bbox&&(r.bbox=t.bbox),r}function u(t,e,n){var i=r.feature(a(t.geometry,e,n),t.properties);return t.id&&(i.id=t.id),t.bbox&&(i.bbox=t.bbox),i}function l(t){var e,n,r,i=o(t);if(2===i.length&&!c(i[0],i[1]))return i;var s=[],a=i.length-1;s.push(i[0]);for(var u=1;u=Math.abs(f)?h>0?o<=r&&r<=a:a<=r&&r<=o:f>0?s<=i&&i<=u:u<=i&&i<=s)}t.exports=function(t,e){if(!t)throw new Error(\\\"geojson is required\\\");var n=s(t),r=[];switch(n){case\\\"LineString\\\":r=l(t);break;case\\\"MultiLineString\\\":case\\\"Polygon\\\":o(t).forEach(function(t){r.push(l(t))});break;case\\\"MultiPolygon\\\":o(t).forEach(function(t){var e=[];t.forEach(function(t){e.push(l(t))}),r.push(e)});break;case\\\"Point\\\":return t;case\\\"MultiPoint\\\":var i={};o(t).forEach(function(t){var e=t.join(\\\"-\\\");i.hasOwnProperty(e)||(r.push(t),i[e]=!0)});break;default:throw new Error(n+\\\" geometry not supported\\\")}return t.coordinates?!0===e?(t.coordinates=r,t):a(t,n,r):!0===e?(t.geometry.coordinates=r,t):u(t,n,r)}},d3f4:function(t,e){t.exports=function(t){return\\\"object\\\"===typeof t?null!==t:\\\"function\\\"===typeof t}},d425:function(t,e,n){\\\"use strict\\\";if(t.exports)var r=n(\\\"c226\\\");function i(t,e){if(!(this instanceof i))return new i(t,e);this.lat=Number(t),this.lon=Number(e)}i.prototype.distanceTo=function(t,e){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");e=void 0===e?6371e3:Number(e);var n=e,r=this.lat.toRadians(),o=this.lon.toRadians(),s=t.lat.toRadians(),a=t.lon.toRadians(),u=s-r,l=a-o,c=Math.sin(u/2)*Math.sin(u/2)+Math.cos(r)*Math.cos(s)*Math.sin(l/2)*Math.sin(l/2),h=2*Math.atan2(Math.sqrt(c),Math.sqrt(1-c)),f=n*h;return f},i.prototype.bearingTo=function(t){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");var e=this.lat.toRadians(),n=t.lat.toRadians(),r=(t.lon-this.lon).toRadians(),o=Math.sin(r)*Math.cos(n),s=Math.cos(e)*Math.sin(n)-Math.sin(e)*Math.cos(n)*Math.cos(r),a=Math.atan2(o,s);return(a.toDegrees()+360)%360},i.prototype.finalBearingTo=function(t){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");return(t.bearingTo(this)+180)%360},i.prototype.midpointTo=function(t){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");var e=this.lat.toRadians(),n=this.lon.toRadians(),r=t.lat.toRadians(),o=(t.lon-this.lon).toRadians(),s=Math.cos(r)*Math.cos(o),a=Math.cos(r)*Math.sin(o),u=Math.sqrt((Math.cos(e)+s)*(Math.cos(e)+s)+a*a),l=Math.sin(e)+Math.sin(r),c=Math.atan2(l,u),h=n+Math.atan2(a,Math.cos(e)+s);return new i(c.toDegrees(),(h.toDegrees()+540)%360-180)},i.prototype.intermediatePointTo=function(t,e){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");var n=this.lat.toRadians(),r=this.lon.toRadians(),o=t.lat.toRadians(),s=t.lon.toRadians(),a=Math.sin(n),u=Math.cos(n),l=Math.sin(r),c=Math.cos(r),h=Math.sin(o),f=Math.cos(o),g=Math.sin(s),d=Math.cos(s),p=o-n,v=s-r,y=Math.sin(p/2)*Math.sin(p/2)+Math.cos(n)*Math.cos(o)*Math.sin(v/2)*Math.sin(v/2),m=2*Math.atan2(Math.sqrt(y),Math.sqrt(1-y)),x=Math.sin((1-e)*m)/Math.sin(m),E=Math.sin(e*m)/Math.sin(m),w=x*u*c+E*f*d,b=x*u*l+E*f*g,I=x*a+E*h,N=Math.atan2(I,Math.sqrt(w*w+b*b)),C=Math.atan2(b,w);return new i(N.toDegrees(),(C.toDegrees()+540)%360-180)},i.prototype.destinationPoint=function(t,e,n){n=void 0===n?6371e3:Number(n);var r=Number(t)/n,o=Number(e).toRadians(),s=this.lat.toRadians(),a=this.lon.toRadians(),u=Math.sin(s),l=Math.cos(s),c=Math.sin(r),h=Math.cos(r),f=Math.sin(o),g=Math.cos(o),d=u*h+l*c*g,p=Math.asin(d),v=f*c*l,y=h-u*d,m=a+Math.atan2(v,y);return new i(p.toDegrees(),(m.toDegrees()+540)%360-180)},i.intersection=function(t,e,n,r){if(!(t instanceof i))throw new TypeError(\\\"p1 is not LatLon object\\\");if(!(n instanceof i))throw new TypeError(\\\"p2 is not LatLon object\\\");var o=t.lat.toRadians(),s=t.lon.toRadians(),a=n.lat.toRadians(),u=n.lon.toRadians(),l=Number(e).toRadians(),c=Number(r).toRadians(),h=a-o,f=u-s,g=2*Math.asin(Math.sqrt(Math.sin(h/2)*Math.sin(h/2)+Math.cos(o)*Math.cos(a)*Math.sin(f/2)*Math.sin(f/2)));if(0==g)return null;var d=Math.acos((Math.sin(a)-Math.sin(o)*Math.cos(g))/(Math.sin(g)*Math.cos(o)));isNaN(d)&&(d=0);var p=Math.acos((Math.sin(o)-Math.sin(a)*Math.cos(g))/(Math.sin(g)*Math.cos(a))),v=Math.sin(u-s)>0?d:2*Math.PI-d,y=Math.sin(u-s)>0?2*Math.PI-p:p,m=l-v,x=y-c;if(0==Math.sin(m)&&0==Math.sin(x))return null;if(Math.sin(m)*Math.sin(x)<0)return null;var E=Math.acos(-Math.cos(m)*Math.cos(x)+Math.sin(m)*Math.sin(x)*Math.cos(g)),w=Math.atan2(Math.sin(g)*Math.sin(m)*Math.sin(x),Math.cos(x)+Math.cos(m)*Math.cos(E)),b=Math.asin(Math.sin(o)*Math.cos(w)+Math.cos(o)*Math.sin(w)*Math.cos(l)),I=Math.atan2(Math.sin(l)*Math.sin(w)*Math.cos(o),Math.cos(w)-Math.sin(o)*Math.sin(b)),N=s+I;return new i(b.toDegrees(),(N.toDegrees()+540)%360-180)},i.prototype.crossTrackDistanceTo=function(t,e,n){if(!(t instanceof i))throw new TypeError(\\\"pathStart is not LatLon object\\\");if(!(e instanceof i))throw new TypeError(\\\"pathEnd is not LatLon object\\\");var r=void 0===n?6371e3:Number(n),o=t.distanceTo(this,r)/r,s=t.bearingTo(this).toRadians(),a=t.bearingTo(e).toRadians(),u=Math.asin(Math.sin(o)*Math.sin(s-a));return u*r},i.prototype.alongTrackDistanceTo=function(t,e,n){if(!(t instanceof i))throw new TypeError(\\\"pathStart is not LatLon object\\\");if(!(e instanceof i))throw new TypeError(\\\"pathEnd is not LatLon object\\\");var r=void 0===n?6371e3:Number(n),o=t.distanceTo(this,r)/r,s=t.bearingTo(this).toRadians(),a=t.bearingTo(e).toRadians(),u=Math.asin(Math.sin(o)*Math.sin(s-a)),l=Math.acos(Math.cos(o)/Math.abs(Math.cos(u)));return l*Math.sign(Math.cos(a-s))*r},i.prototype.maxLatitude=function(t){var e=Number(t).toRadians(),n=this.lat.toRadians(),r=Math.acos(Math.abs(Math.sin(e)*Math.cos(n)));return r.toDegrees()},i.crossingParallels=function(t,e,n){var r=Number(n).toRadians(),i=t.lat.toRadians(),o=t.lon.toRadians(),s=e.lat.toRadians(),a=e.lon.toRadians(),u=a-o,l=Math.sin(i)*Math.cos(s)*Math.cos(r)*Math.sin(u),c=Math.sin(i)*Math.cos(s)*Math.cos(r)*Math.cos(u)-Math.cos(i)*Math.sin(s)*Math.cos(r),h=Math.cos(i)*Math.cos(s)*Math.sin(r)*Math.sin(u);if(h*h>l*l+c*c)return null;var f=Math.atan2(-c,l),g=Math.acos(h/Math.sqrt(l*l+c*c)),d=o+f-g,p=o+f+g;return{lon1:(d.toDegrees()+540)%360-180,lon2:(p.toDegrees()+540)%360-180}},i.prototype.rhumbDistanceTo=function(t,e){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");e=void 0===e?6371e3:Number(e);var n=e,r=this.lat.toRadians(),o=t.lat.toRadians(),s=o-r,a=Math.abs(t.lon-this.lon).toRadians();a>Math.PI&&(a-=2*Math.PI);var u=Math.log(Math.tan(o/2+Math.PI/4)/Math.tan(r/2+Math.PI/4)),l=Math.abs(u)>1e-11?s/u:Math.cos(r),c=Math.sqrt(s*s+l*l*a*a),h=c*n;return h},i.prototype.rhumbBearingTo=function(t){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");var e=this.lat.toRadians(),n=t.lat.toRadians(),r=(t.lon-this.lon).toRadians();r>Math.PI&&(r-=2*Math.PI),r<-Math.PI&&(r+=2*Math.PI);var o=Math.log(Math.tan(n/2+Math.PI/4)/Math.tan(e/2+Math.PI/4)),s=Math.atan2(r,o);return(s.toDegrees()+360)%360},i.prototype.rhumbDestinationPoint=function(t,e,n){n=void 0===n?6371e3:Number(n);var r=Number(t)/n,o=this.lat.toRadians(),s=this.lon.toRadians(),a=Number(e).toRadians(),u=r*Math.cos(a),l=o+u;Math.abs(l)>Math.PI/2&&(l=l>0?Math.PI-l:-Math.PI-l);var c=Math.log(Math.tan(l/2+Math.PI/4)/Math.tan(o/2+Math.PI/4)),h=Math.abs(c)>1e-11?u/c:Math.cos(o),f=r*Math.sin(a)/h,g=s+f;return new i(l.toDegrees(),(g.toDegrees()+540)%360-180)},i.prototype.rhumbMidpointTo=function(t){if(!(t instanceof i))throw new TypeError(\\\"point is not LatLon object\\\");var e=this.lat.toRadians(),n=this.lon.toRadians(),r=t.lat.toRadians(),o=t.lon.toRadians();Math.abs(o-n)>Math.PI&&(n+=2*Math.PI);var s=(e+r)/2,a=Math.tan(Math.PI/4+e/2),u=Math.tan(Math.PI/4+r/2),l=Math.tan(Math.PI/4+s/2),c=((o-n)*Math.log(l)+n*Math.log(u)-o*Math.log(a))/Math.log(u/a);isFinite(c)||(c=(n+o)/2);var h=i(s.toDegrees(),(c.toDegrees()+540)%360-180);return h},i.areaOf=function(t,e){var n=void 0===e?6371e3:Number(e),r=t[0].equals(t[t.length-1]);r||t.push(t[0]);for(var i=t.length-1,o=0,s=0;s180?-(360-o):o;return c}},d841:function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"6991\\\"),o=n(\\\"feb7\\\"),s=n(\\\"0136\\\"),a=n(\\\"4f6b\\\"),u=n(\\\"00a2\\\"),l=n(\\\"fa64\\\"),c=n(\\\"e868\\\"),h=n(\\\"b24d\\\"),f=u.getCoords,g=o.lineString,d=u.getGeomType,p=r.featureEach,v=r.featureReduce,y=o.featureCollection;function m(t,e){var n=[],r=i();return p(e,function(e){if(n.forEach(function(t,e){t.id=e}),n.length){var i=r.search(e),o=E(e,i);n=n.filter(function(t){return t.id!==o.id}),r.remove(o),p(x(o,e),function(t){n.push(t),r.insert(t)})}else n=x(t,e).features,r.load(y(n))}),y(n)}function x(t,e){var n=[],r=f(t)[0],o=f(t)[t.geometry.coordinates.length-1];if(w(r,f(e))||w(o,f(e)))return y([t]);var s=i(),a=l(t);s.load(a);var u=s.search(e);if(!u.features.length)return y([t]);var c=E(e,u),h=[r],d=v(a,function(t,r,i){var o=f(r)[1],s=f(e);return i===c.id?(t.push(s),n.push(g(t)),w(s,o)?[s]:[s,o]):(t.push(o),t)},h);return d.length>1&&n.push(g(d)),y(n)}function E(t,e){if(!e.features)throw new Error(\\\" must contain features\\\");if(1===e.features.length)return e.features[0];var n,r=1/0;return p(e,function(e){var i=c(e,t),o=i.properties.dist;os&&(s=t[0]),t[1]a&&(a=t[1])}function l(t){switch(t.type){case\\\"GeometryCollection\\\":t.geometries.forEach(l);break;case\\\"Point\\\":u(t.coordinates);break;case\\\"MultiPoint\\\":t.coordinates.forEach(u);break}}for(e in t.arcs.forEach(function(t){var e,i=-1,u=t.length;while(++is&&(s=e[0]),e[1]a&&(a=e[1])}),t.objects)l(t.objects[e]);return[r,o,s,a]},s=function(t,e){var n,r=t.length,i=r-e;while(i<--r)n=t[i],t[i++]=t[r],t[r]=n},a=function(t,e){return\\\"GeometryCollection\\\"===e.type?{type:\\\"FeatureCollection\\\",features:e.geometries.map(function(e){return u(t,e)})}:u(t,e)};function u(t,e){var n=e.id,r=e.bbox,i=null==e.properties?{}:e.properties,o=l(t,e);return null==n&&null==r?{type:\\\"Feature\\\",properties:i,geometry:o}:null==r?{type:\\\"Feature\\\",id:n,properties:i,geometry:o}:{type:\\\"Feature\\\",id:n,bbox:r,properties:i,geometry:o}}function l(t,e){var n=i(t.transform),r=t.arcs;function o(t,e){e.length&&e.pop();for(var i=r[t<0?~t:t],o=0,a=i.length;o1)r=g(t,e,n);else for(i=0,r=new Array(o=t.arcs.length);i1)for(var o,s,u=1,l=a(i[0]);ul&&(s=i[0],i[0]=i[u],i[u]=s,l=o);return i})}}var y=function(t,e){var n=0,r=t.length;while(n>>1;t[i]=2))throw new Error(\\\"n must be ≥2\\\");u=t.bbox||o(t);var n,r=u[0],i=u[1],s=u[2],a=u[3];e={scale:[s-r?(s-r)/(n-1):1,a-i?(a-i)/(n-1):1],translate:[r,i]}}var u,l,c=x(e),h=t.objects,f={};function g(t){return c(t)}function d(t){var e;switch(t.type){case\\\"GeometryCollection\\\":e={type:\\\"GeometryCollection\\\",geometries:t.geometries.map(d)};break;case\\\"Point\\\":e={type:\\\"Point\\\",coordinates:g(t.coordinates)};break;case\\\"MultiPoint\\\":e={type:\\\"MultiPoint\\\",coordinates:t.coordinates.map(g)};break;default:return t}return null!=t.id&&(e.id=t.id),null!=t.bbox&&(e.bbox=t.bbox),null!=t.properties&&(e.properties=t.properties),e}function p(t){var e,n=0,r=1,i=t.length,o=new Array(i);o[0]=c(t[0],0);while(++n=i?(o=g,c+=1,ct[0]&&(e[0]=t[0]),e[1]>t[1]&&(e[1]=t[1]),e[2]0&&(b=w.features[0],b.properties.dist=s(e,b,n),b.properties.location=a+s(d,b,n)),d.properties.distt[0]&&(e[0]=t[0]),e[1]>t[1]&&(e[1]=t[1]),e[2]e[0])&&(!(t[2]e[1])&&!(t[3]w/2;R&&(P-=w/4);for(var T=a([]),O=0;O0)for(var r=0;r0}function g(t,e){return i(e,t)}function d(t,e){var n=!1,i=!1,o=t.coordinates[0].length,s=0;while(s=Math.abs(a)?s>0?t[0]<=n[0]&&n[0]<=e[0]:e[0]<=n[0]&&n[0]<=t[0]:a>0?t[1]<=n[1]&&n[1]<=e[1]:e[1]<=n[1]&&n[1]<=t[1]:Math.abs(s)>=Math.abs(a)?s>0?t[0]0?t[1]\\n*/function r(t,e,n){var r,i;if(!Array.isArray(e))throw new Error(\\\"Get closest expects an array as second argument\\\");return e.forEach(function(e,o){var s=n(e,t);s>=0&&(\\\"undefined\\\"==typeof i||s1)for(var n=1;n1?arguments[1]:void 0,e.length)),r=String(t);return a?a.call(e,r,n):e.slice(n,n+r.length)===r}})},f6b4:function(t,e,n){\\\"use strict\\\";var r=n(\\\"c532\\\");function i(){this.handlers=[]}i.prototype.use=function(t,e){return this.handlers.push({fulfilled:t,rejected:e}),this.handlers.length-1},i.prototype.eject=function(t){this.handlers[t]&&(this.handlers[t]=null)},i.prototype.forEach=function(t){r.forEach(this.handlers,function(e){null!==e&&t(e)})},t.exports=i},f7b4:function(t,e,n){var r=n(\\\"00a2\\\"),i=r.getCoords,o=n(\\\"716c\\\").featureEach;function s(t,e){var n={};o(t,function(t){var e=i(t)[1];n[e]||(n[e]=[]),n[e].push(t)});var r=Object.keys(n).map(function(t){var e=n[t],r=e.sort(function(t,e){return i(t)[0]-i(e)[0]});return r}),s=r.sort(function(t,n){return e?i(t[0])[1]-i(n[0])[1]:i(n[0])[1]-i(t[0])[1]});return s}t.exports=function(t,e,n){r.collectionOf(t,\\\"Point\\\",\\\"input must contain Points\\\"),e=e||\\\"elevation\\\";for(var i=s(t,n),o=[],a=0;ai?n:i,l=r>o?r:o;return[s,a,u,l]}t.exports=function(t){if(!t)throw new Error(\\\"geojson is required\\\");var e=[];return o(t,function(t){u(t,e)}),a(e)}},fab2:function(t,e,n){var r=n(\\\"7726\\\").document;t.exports=r&&r.documentElement},fabd:function(t,e,n){var r,i,o;\\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* @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(function(s,a){i=[n(\\\"b07d\\\"),n(\\\"1419\\\")],r=a,o=\\\"function\\\"===typeof r?r.apply(e,i):r,void 0===o||(t.exports=o)})(0,function(t,e){return{isoBands:\\\"function\\\"===typeof t?t:\\\"object\\\"===typeof t&&\\\"function\\\"===typeof t.isoBands?t.isoBands:null,isoContours:\\\"function\\\"===typeof e?e:\\\"object\\\"===typeof e&&\\\"function\\\"===typeof e.isoContours?e.isoContours:null}})},fda4:function(t,e,n){var r=n(\\\"a8e7\\\"),i=n(\\\"b6b7\\\"),o=n(\\\"8678\\\"),s=n(\\\"c583\\\"),a=n(\\\"0354\\\"),u=n(\\\"34eb\\\")(\\\"simplepolygon\\\"),l=n(\\\"34eb\\\")(\\\"simplepolygon:all\\\");t.exports=function(t){if(\\\"Feature\\\"!=t.type)throw new Error(\\\"The input must a geojson object of type Feature\\\");if(void 0===t.geometry||null==t.geometry)throw new Error(\\\"The input must a geojson object with a non-empty geometry\\\");if(\\\"Polygon\\\"!=t.geometry.type)throw new Error(\\\"The input must be a geojson Polygon\\\");for(var e=t.geometry.coordinates.length,n=[],v=0;vN[e.isect].coord?-1:1}),l(\\\"Initial state of the queue: \\\"+JSON.stringify(T)),u(\\\"Setting up queue\\\");w=[];while(T.length>0){var k=T.pop(),G=k.isect,V=k.parent,q=k.winding,B=w.length,z=[N[G].coord];l(\\\"# Starting output ring number \\\"+w.length+\\\" with winding \\\"+q+\\\" from intersection \\\"+G),G1)for(e=0;e=0==e}function g(t){for(var e=0,n=0;n=0))throw new Error(\\\"precision must be a positive number\\\");var n=Math.pow(10,e||0);return Math.round(t*n)/n}function p(t,e){if(void 0===t||null===t)throw new Error(\\\"radians is required\\\");var n=f[e||\\\"kilometers\\\"];if(!n)throw new Error(\\\"units is invalid\\\");return t*n}function v(t,e){if(void 0===t||null===t)throw new Error(\\\"distance is required\\\");var n=f[e||\\\"kilometers\\\"];if(!n)throw new Error(\\\"units is invalid\\\");return t/n}function y(t,e){return x(v(t,e))}function m(t){if(null===t||void 0===t)throw new Error(\\\"bearing is required\\\");var e=t%360;return e<0&&(e+=360),e}function x(t){if(null===t||void 0===t)throw new Error(\\\"radians is required\\\");var e=t%(2*Math.PI);return 180*e/Math.PI}function E(t){if(null===t||void 0===t)throw new Error(\\\"degrees is required\\\");var e=t%360;return e*Math.PI/180}function w(t,e,n){if(null===t||void 0===t)throw new Error(\\\"distance is required\\\");if(!(t>=0))throw new Error(\\\"distance must be a positive number\\\");var r=p(v(t,e),n||\\\"kilometers\\\");return r}function b(t,e,n){if(null===t||void 0===t)throw new Error(\\\"area is required\\\");if(!(t>=0))throw new Error(\\\"area must be a positive number\\\");var r=g[e||\\\"meters\\\"];if(!r)throw new Error(\\\"invalid original units\\\");var i=g[n||\\\"kilometers\\\"];if(!i)throw new Error(\\\"invalid final units\\\");return t/r*i}function I(t){return!isNaN(t)&&null!==t&&!Array.isArray(t)}t.exports={feature:n,geometry:r,featureCollection:a,geometryCollection:h,point:i,multiPoint:l,lineString:s,multiLineString:u,polygon:o,multiPolygon:c,radiansToDistance:p,distanceToRadians:v,distanceToDegrees:y,radians2degrees:x,degrees2radians:E,bearingToAngle:m,convertDistance:w,convertArea:b,round:d,isNumber:I}},ff54:function(t,e,n){var r=n(\\\"716c\\\"),i=n(\\\"feb7\\\"),o=n(\\\"00a2\\\").getCoords,s=n(\\\"8de3\\\"),a=r.flattenEach,u=i.lineString,l=i.multiLineString,c=i.distanceToDegrees;function h(t,e,n){var r=[],i=c(e,n),a=o(t),l=[];return a.forEach(function(t,e){if(e!==a.length-1){var n=f(t,a[e+1],i);if(r.push(n),e>0){var o=r[e-1],u=s(n,o);!1!==u&&(o[1]=u,n[0]=u),l.push(o[0]),e===a.length-2&&(l.push(n[0]),l.push(n[1]))}2===a.length&&(l.push(n[0]),l.push(n[1]))}}),u(l,t.properties)}function f(t,e,n){var r=Math.sqrt((t[0]-e[0])*(t[0]-e[0])+(t[1]-e[1])*(t[1]-e[1])),i=t[0]+n*(e[1]-t[1])/r,o=e[0]+n*(e[1]-t[1])/r,s=t[1]+n*(t[0]-e[0])/r,a=e[1]+n*(t[0]-e[0])/r;return[[i,s],[o,a]]}t.exports=function(t,e,n){if(!t)throw new Error(\\\"geojson is required\\\");if(void 0===e||null===e||isNaN(e))throw new Error(\\\"distance is required\\\");var r=\\\"Feature\\\"===t.type?t.geometry.type:t.type,i=t.properties;switch(r){case\\\"LineString\\\":return h(t,e,n);case\\\"MultiLineString\\\":var o=[];return a(t,function(t){o.push(h(t,e,n).geometry.coordinates)}),l(o,i);default:throw new Error(\\\"geometry \\\"+r+\\\" is not supported\\\")}}}});\\n//# sourceMappingURL=fed9d76501cdc7810a86.worker.js.map\"])), { name: \"[hash].worker.js\" })\n\t\t\t\t\taddMethods(w, methods)\n\t\t\t\t\t\n\t\t\t\t\treturn w\n\t\t\t\t}\n\t\t\t","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\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 baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\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","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\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 * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n}\n\nmodule.exports = arrayAggregator;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\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 getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\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","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","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","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\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","const mutations = {\r\n // root\r\n setRootCropRotations (state, rotations) {\r\n state.cropRotations.root = rotations\r\n },\r\n addCropRotation (state, cropRotation) {\r\n state.cropRotations.root.push(cropRotation)\r\n },\r\n updateCropRotation (state, cropRotation) {\r\n const cropRotationToUpdate = state.cropRotations.root.find(cr => cr.id === cropRotation.id)\r\n state.cropRotations.root.splice(state.cropRotations.root.indexOf(cropRotationToUpdate), 1, cropRotation)\r\n },\r\n removeCropRotation (state, cropRotationId) {\r\n const cropRotationToRemove = state.cropRotations.root.find(cr => cr.id === cropRotationId)\r\n state.cropRotations.root.splice(state.cropRotations.root.indexOf(cropRotationToRemove), 1)\r\n },\r\n // org unit\r\n setAssignedCropRotationsForOrgUnit (state, cropRotations) {\r\n state.cropRotations.company = cropRotations\r\n },\r\n // field\r\n assignCropRotationToField (state, cropRotation) {\r\n state.cropRotations.field = cropRotation\r\n },\r\n unassignCropRotationFromField (state) {\r\n state.cropRotations.field = null\r\n }\r\n}\r\n\r\nexport default mutations\r\n","// workflow definition spec\r\n//\r\n// name:\r\n// OPTIONAL used for automatic translation keys (title and status bar of left sidebar for example)\r\n// only required if name differs from titlecased workflow name (titlecased for legacy translation reasons)\r\n// component: componentName\r\n// VARIANT 1\r\n// OPTIONAL defines which component to use in the right sidebar\r\n// only required if the component name differs from titlecased workflow name\r\n// the component still has to be imported/registered in RightSidebar.vue\r\n// VARIANT 2\r\n// async component for lazy loading the component\r\n// no registration in RightSidebar.vue necessary\r\n// wide: true\r\n// use a 800px right sidebar instead of 400px\r\n// breadcrumbs: true\r\n// display standard breadcrumbs (WorkflowHeader.vue)\r\n// usePortals: true\r\n// use the `workflowLeft` portal target for displaying components in the left sidebar\r\n// when this is used, the left sidebar component can and should be included inside the module root component\r\n// alias: workflowName\r\n// defer all options to another workflow, providing an alias for navigation reasons\r\n// ONLY this option should be specified for alias workflows\r\n// left: componentName\r\n// which component to display in the left sidebar\r\n// the component still has to be imported/registered in WorkflowLeft.vue\r\n// DEPRECATED in favor of `usePortals`\r\n\r\nconst workflows = {\r\n cultivationsDisplayField: {\r\n wide: true,\r\n breadcrumbs: true,\r\n component: 'field-cultivation-plan'\r\n },\r\n actionDisplayField: {\r\n breadcrumbs: true,\r\n component: 'actions-for-field'\r\n },\r\n cultivationPlanning: {},\r\n cultivationPlanningOrgUnit: {\r\n name: 'cultivation-planning',\r\n component: 'cultivation-planning',\r\n left: 'CultivationPlanningFieldSelection'\r\n },\r\n editCultivationPlanningOrgUnit: {alias: 'cultivationPlanning'},\r\n cropRotation: {\r\n wide: true,\r\n breadcrumbs: true,\r\n component: 'crop-rotation-management'\r\n },\r\n cultivationPlan: {\r\n wide: true,\r\n breadcrumbs: true,\r\n component: 'org-unit-cultivation-plan'\r\n },\r\n mixtureManagement: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n machinesOverview: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n nutritionStatusForm: {},\r\n personsOverview: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n companyMixtureManagement: {\r\n wide: true\r\n },\r\n actionDetailsPage: {\r\n breadcrumbs: true\r\n },\r\n weatherDetails: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n actionPlanning: {\r\n wide: true,\r\n left: 'ActionPlanningFieldSelection',\r\n fieldSelection: true\r\n },\r\n actionPlanningForSingleField: {\r\n wide: true,\r\n component: 'action-planning'\r\n },\r\n cultivationPlanningFromOrgUnit: {alias: 'cultivationPlanning'},\r\n actionPlanningForSingleFieldFromList: {alias: 'actionPlanningForSingleField'},\r\n actionPlanningFromOverview: {alias: 'actionPlanning'},\r\n actionPlanningFromCollection: {alias: 'actionPlanning'},\r\n actionPlanningFromDashboard: {alias: 'actionPlanning'},\r\n lanePlanning: {\r\n component: () => import('@frs/components/lane-planning/LanePlanningModuleRoot')\r\n },\r\n actionOverview: {\r\n wide: true,\r\n breadcrumbs: true,\r\n component: 'ActionsForOrgUnit'\r\n },\r\n companyData: {},\r\n newCompanyData: {alias: 'companyData'},\r\n companyNumbers: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n companyAccounts: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n nutrientRequirement: {},\r\n basicFertilization: {\r\n breadcrumbs: true,\r\n left: 'BasicFertilizationFieldSelection'\r\n },\r\n samplingOrderCreation: {\r\n left: 'SamplingOrderCreationFieldSelection'\r\n },\r\n samplingOrderPlanning: {\r\n left: 'SamplingOrderPlanningFieldSelection'\r\n },\r\n probingOrderExport: {\r\n left: 'BasicFertilizationFieldSelection'\r\n },\r\n probingResultManualSettings: {\r\n left: 'BasicFertilizationFieldSelection'\r\n },\r\n probingResultManualValues: {\r\n wide: true,\r\n left: 'BasicFertilizationFieldSelection'\r\n },\r\n probingResultUpload: {\r\n wide: true,\r\n breadcrumbs: true,\r\n left: 'BasicFertilizationFieldSelection'\r\n },\r\n nutrientMapDisplay: {\r\n left: 'NutrientMapsFieldSelection'\r\n },\r\n applicationMapCreation: {\r\n left: 'BasicFertilizationApplicationMapFieldSelection'\r\n },\r\n applicationMapPreview: {\r\n wide: true,\r\n left: 'ApplicationMapPreviewFieldSelection'\r\n },\r\n lanePlanSelectionOrgUnit: {\r\n breadcrumbs: true,\r\n component: () => import('@frs/components/lane-planning/LanePlanningModuleRoot')\r\n },\r\n lanePlanExport: {\r\n component: 'ResultPage',\r\n breadcrumbs: true\r\n },\r\n lanePlanDetail: {\r\n component: 'DetailView',\r\n breadcrumbs: true\r\n },\r\n entityImportPreview: {\r\n breadcrumbs: true,\r\n left: 'EntityImportEntitySelection'\r\n },\r\n defaultYields: {\r\n breadcrumbs: true\r\n },\r\n simpleApplicationMaps: {\r\n breadcrumbs: true\r\n },\r\n maizeSowing: {\r\n breadcrumbs: true\r\n },\r\n mapManagement: {\r\n wide: true,\r\n breadcrumbs: true\r\n },\r\n mapDetails: {\r\n breadcrumbs: true\r\n },\r\n applicationMapCreationResult: {\r\n breadcrumbs: true\r\n },\r\n applicationMapCreationResultMaizeSowing: {alias: 'applicationMapCreationResult'},\r\n applicationMapCreationResultSimpleApplicationMaps: {alias: 'applicationMapCreationResult'},\r\n applicationMapCreationResultBasicFertilization: {alias: 'applicationMapCreationResult'},\r\n applicationMapCreationResultSimon: {alias: 'applicationMapCreationResult'},\r\n telemetry: {\r\n breadcrumbs: true\r\n },\r\n simonModule: {\r\n breadcrumbs: true\r\n },\r\n applicationDetails: {},\r\n yieldDetails: {},\r\n algorithmicApplicationMapCreation: {},\r\n zoneMapImportSettings: {},\r\n soilMapImportSettings: {}\r\n}\r\n\r\nObject.keys(workflows).forEach(key => {\r\n const workflow = workflows[key]\r\n\r\n if (workflow.alias) return\r\n\r\n if (!workflow.component) {\r\n workflow.component = key[0].toUpperCase() + key.substring(1)\r\n }\r\n if (!workflow.name) {\r\n workflow.name = key[0].toUpperCase() + key.substring(1) // titlecased for legacy reasons\r\n }\r\n})\r\n\r\nexport default workflows\r\n","import workflows from './workflows'\r\n\r\nconst mutations = {\r\n setLeftView (state, view) {\r\n state.ui.view.left = view\r\n },\r\n setRightView (state, view) {\r\n state.ui.view.right = view\r\n state.ui.workflow = workflows[view]\r\n // resolve workflow alias\r\n if (state.ui.workflow && state.ui.workflow.alias) {\r\n state.ui.workflow = workflows[state.ui.workflow.alias]\r\n }\r\n state.ui.view.expanded = !!state.ui.workflow && !!state.ui.workflow.wide\r\n\r\n // scroll to top\r\n const sidebarContent = document.querySelector('.right-sidebar-content')\r\n if (sidebarContent) {\r\n sidebarContent.scrollTop = 0\r\n }\r\n },\r\n setDataLoading (state, value) {\r\n state.ui.loadingData = value\r\n },\r\n setWorkflow (state, partialWorkflow) {\r\n const currentWorkflow = state.ui.workflow\r\n for (const key in partialWorkflow) {\r\n if (key in currentWorkflow) {\r\n Object.assign(state.ui.workflow, partialWorkflow)\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport default mutations\r\n","const mutations = {\r\n setRightSidebarCollapsed (state, collapsed) {\r\n state.ui.view.rightCollapsed = collapsed\r\n },\r\n setLeftSidebarCollapsed (state, collapsed) {\r\n state.ui.view.leftCollapsed = collapsed\r\n }\r\n}\r\nexport default mutations\r\n","import Vue from 'vue'\r\n\r\nconst mutations = {\r\n updateFieldData (state, dataByFieldId) {\r\n const newData = {}\r\n for (const fieldId in dataByFieldId) {\r\n const data = {\r\n ...state.data.field[fieldId],\r\n ...dataByFieldId[fieldId]\r\n }\r\n newData[fieldId] = data\r\n }\r\n state.data.field = {...state.data.field, ...newData}\r\n },\r\n updateOrgUnitData (state, dataByOrgUnitId) {\r\n const newData = {}\r\n for (const orgUnitId in dataByOrgUnitId) {\r\n const data = {\r\n ...state.data.orgUnits.data[orgUnitId],\r\n ...dataByOrgUnitId[orgUnitId]\r\n }\r\n newData[orgUnitId] = data\r\n }\r\n state.data.orgUnits.data = {...state.data.orgUnits.data, ...newData}\r\n },\r\n setIsNewEntity (state, value) {\r\n state.ui.isNewEntity = value\r\n },\r\n deleteMasterData (state, orgUnitId) {\r\n const data = {...state.data.orgUnits.data[orgUnitId]}\r\n data.companyNumbers = []\r\n data.companyData = null\r\n\r\n Vue.set(state.data.orgUnits.data, orgUnitId, data)\r\n },\r\n addEmptyMasterData (state, orgUnitId) {\r\n const data = {\r\n companyNumbers: [],\r\n companyData: {}\r\n }\r\n Vue.set(state.data.orgUnits.data, orgUnitId, Object.assign({}, state.data.orgUnits.data[orgUnitId], data))\r\n },\r\n updateCompanyNumber (state, {orgUnitId, companyNumber}) {\r\n const orgUnitData = state.data.orgUnits.data\r\n\r\n orgUnitData[orgUnitId].companyNumbers = orgUnitData[orgUnitId].companyNumbers\r\n .filter(x => x.id !== companyNumber.id)\r\n .concat(companyNumber)\r\n },\r\n removeCompanyNumber (state, {orgUnitId, companyNumberId}) {\r\n const orgUnitData = state.data.orgUnits.data\r\n\r\n orgUnitData[orgUnitId].companyNumbers = orgUnitData[orgUnitId].companyNumbers\r\n .filter(x => x.id !== companyNumberId)\r\n },\r\n setEntityStructureEditing (state, visibility) {\r\n state.ui.entityStructureEditing = visibility\r\n }\r\n}\r\n\r\nexport default mutations\r\n","import {makeSetters} from 'src/js/helpers/vuex/mutations'\r\n\r\nexport default {\r\n ...makeSetters([\r\n 'data.crops',\r\n 'data.soilTypes',\r\n 'data.soilSubTypes',\r\n 'data.usageTypes',\r\n 'data.legalForms',\r\n 'data.companyForms',\r\n 'data.waterExtractionSources'\r\n ])\r\n}\r\n","import Vue from 'vue'\r\n\r\nexport const mutations = {\r\n setUserSettings (state, partialSettings) {\r\n delete partialSettings.ui\r\n Object.assign(state.userSettings, partialSettings)\r\n },\r\n setUserUiSettings (state, {flag, value}) {\r\n value\r\n ? Vue.set(state.userSettings.ui, flag, value)\r\n : Vue.delete(state.userSettings.ui, flag)\r\n },\r\n setFieldTags (state, {id, tags}) {\r\n if (tags.length) {\r\n Vue.set(state.userSettings.tags.fields, id, tags)\r\n } else {\r\n Vue.delete(state.userSettings.tags.fields, id)\r\n }\r\n },\r\n setFavoriteState (state, {id, favorited, type}) {\r\n if (favorited && !state.userSettings.favorites[type].includes(id)) {\r\n state.userSettings.favorites[type].push(id)\r\n } else {\r\n state.userSettings.favorites[type] = state.userSettings.favorites[type].filter(x => x !== id)\r\n }\r\n }\r\n}\r\n\r\nexport default mutations\r\n","import Vue from 'vue'\r\n\r\nexport function setZoneMapGenerationStatus (state, value) {\r\n state.ui.gettingZoneMap = value\r\n}\r\n\r\nexport function updateZoneMapDetails (state, {fieldId, zoneMapDetails}) {\r\n Vue.set(state.data.field[fieldId], 'latestZoneMap', zoneMapDetails)\r\n}\r\n","import cropRotationMutations from './crop-rotation'\r\nimport navigationMutations from './navigation'\r\nimport layout from './layout'\r\nimport entity from './entity'\r\nimport masterData from './master-data'\r\nimport userData from './user-data'\r\n\r\nimport * as zonemap from './zonemap'\r\n\r\nconst determineEditingComponent = (state) => {\r\n if (state.ui.view.right === 'default' && state.navigation.location.fieldId) {\r\n return 'FieldEditingTools'\r\n }\r\n if (['editCultivationPlanningOrgUnit', 'cultivationPlanningOrgUnit'].includes(state.ui.view.right)) {\r\n return 'CultivationEditingTools'\r\n }\r\n if ([\r\n 'actionPlanningFromOverview',\r\n 'actionPlanningForSingleField',\r\n 'actionPlanningForSingleFieldFromList'\r\n ].includes(state.ui.view.right)) {\r\n return 'ActionEditingTools'\r\n }\r\n if (state.ui.view.right === 'lanePlanning') {\r\n return 'LanePlanningEditingTools'\r\n }\r\n}\r\n\r\nconst mutations = {\r\n ...navigationMutations,\r\n ...cropRotationMutations,\r\n ...layout,\r\n ...entity,\r\n ...masterData,\r\n ...userData,\r\n ...zonemap,\r\n setEditingComponent (state, componentName) {\r\n state.map.editing.component = componentName || determineEditingComponent(state)\r\n\r\n if (state.map.editing.active && !state.map.editing.component) {\r\n console.error('no valid editing tools component for current state')\r\n }\r\n },\r\n setMainPageLoading (state, value) {\r\n state.ui.mainPageLoading = value\r\n }\r\n}\r\n\r\nexport default mutations\r\n","// import axios from 'axios'\r\n\r\nconst withLoadingIndicator = action => (store, payload) => {\r\n store.commit('setDataLoading', true)\r\n return action(store, payload).then(() => {\r\n store.commit('setDataLoading', false)\r\n })\r\n}\r\n\r\nexport const reloadDefaultFieldData = withLoadingIndicator(({state, dispatch, getters}) => {\r\n const {fieldId} = state.navigation.location\r\n const field = getters['navigation/entityLookup'][fieldId]\r\n if (!field) return Promise.resolve()\r\n\r\n return Promise.all([\r\n dispatch('loadFullFieldData', fieldId),\r\n dispatch('reloadAssignedCropRotations'),\r\n dispatch('fieldRecordSystem/mapManagement/loadGeometryForField', null, {root: true}) // needed for geometry downlaod\r\n ])\r\n})\r\n\r\nexport const reloadWeatherData = ({state, dispatch}) => {\r\n const {fieldId} = state.navigation.location\r\n\r\n if (!fieldId) {\r\n console.error('weather data loaded without fieldId')\r\n return\r\n }\r\n\r\n return dispatch('loadWeatherData', fieldId)\r\n}\r\n\r\n// TODO should probably trigger on selection, not on navigation\r\nexport const reloadOrgUnitData = ({state, dispatch}) => {\r\n const {orgUnitId} = state.navigation.location\r\n if (orgUnitId) {\r\n return Promise.all([\r\n dispatch('loadMasterData', orgUnitId),\r\n dispatch('reloadCropRotations')\r\n ])\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nexport const getAll = urls => Promise.all(urls.map(url => axios.get(url).then(response => response.data)))\r\n\r\nexport const getAndCommit = (url, mutation) => store => {\r\n return axios.get(url)\r\n .then(response => {\r\n store.commit(mutation, response.data)\r\n return store\r\n })\r\n .catch(error => {\r\n console.error(`error while trying to load data from [${url}] to put into mutation [${mutation}]`)\r\n console.error(error)\r\n return store\r\n })\r\n}\r\n","import axios from 'axios'\r\nimport {getAndCommit} from '@helpers/vuex/actions'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport const reloadEntities = ({state, getters, commit}) => {\r\n return smarterGet('/api/v2/entities/{harvestYear}', {\r\n id: 'frs.fullTree',\r\n inputs: {\r\n harvestYear: () => state.userSettings.harvestYear\r\n },\r\n onResult (forest) {\r\n commit('navigation/setEntityForest', forest)\r\n\r\n // TODO move directly into setTree\r\n const newFields = getters.allFields.filter(x => !state.data.field[x.id])\r\n\r\n if (newFields.length) {\r\n const defaultFieldData = newFields.reduce((fieldData, field) => Object.assign(fieldData, {[field.id]: {}}), {})\r\n commit('updateFieldData', defaultFieldData)\r\n }\r\n }\r\n })\r\n}\r\n\r\nexport const reloadSubTreeEntities = ({state, commit, getters, rootState}) => {\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n if (!orgUnitId) return\r\n return smarterGet('/api/v2/entities/{orgUnitId}/{harvestYear}', {\r\n id: 'frs.subTree',\r\n inputs: {\r\n harvestYear: () => state.userSettings.harvestYear,\r\n orgUnitId: () => rootState.fieldRecordSystem.navigation.location.orgUnitId\r\n },\r\n onResult (subtree) {\r\n const {entityLookup} = getters\r\n commit('navigation/setEntitySubTree', {orgUnitId, subtree, entityLookup})\r\n }\r\n })\r\n}\r\n\r\nexport const reloadIrrigationSources = getAndCommit('/api/v2/masterdata/waterExtraction/sources', 'setWaterExtractionSources')\r\nexport const reloadSoilTypes = getAndCommit('/api/v2/masterdata/soil/types', 'setSoilTypes')\r\nexport const reloadSoilSubTypes = getAndCommit('/api/v2/masterdata/soil/subtypes', 'setSoilSubTypes')\r\nexport const reloadUsageTypes = getAndCommit('/api/v2/masterdata/field/usages', 'setUsageTypes')\r\nexport const reloadLegalForms = getAndCommit('/api/v2/masterdata/company/types', 'setLegalForms')\r\nexport const reloadCompanyForms = getAndCommit('/api/v2/masterdata/company/categories', 'setCompanyForms')\r\nexport const reloadMaizeProductData = ({commit}) => {\r\n axios.get('/api/v2/master-data/maize-data')\r\n .then(response => response.data.productSeedRates)\r\n .then(rates => {\r\n commit('setMaizeProductData', rates)\r\n })\r\n}\r\n\r\nexport function preloadStaticData ({dispatch}) {\r\n const rootDispatch = (name, payload) => dispatch(name, payload, {root: true})\r\n\r\n return Promise.all([\r\n dispatch('reloadIrrigationSources'),\r\n rootDispatch('masterData/reloadCrops'),\r\n rootDispatch('masterData/reloadCropUsages'),\r\n rootDispatch('masterData/reloadProductAlgorithms'),\r\n dispatch('reloadSoilTypes'),\r\n dispatch('reloadSoilSubTypes'),\r\n dispatch('reloadUsageTypes'),\r\n dispatch('reloadLegalForms'),\r\n dispatch('reloadCompanyForms'),\r\n rootDispatch('masterData/reloadUnits'),\r\n rootDispatch('masterData/reloadGlobalProducts'),\r\n rootDispatch('masterData/loadPortalSettings'),\r\n dispatch('cultivationPlanning/reloadCultivationTypes'),\r\n dispatch('cultivationPlanning/reloadEcoTypes')\r\n ])\r\n}\r\n","// import {makeFeature} from 'src/js/helpers/openlayers/features'\r\n\r\nexport const loadLotsOfOrgUnitData = ({state, dispatch, getters}, {skipFocus} = {}) => {\r\n const {orgUnitId} = state.navigation.location\r\n // orgUnit can be null, in case user deletes root orgUnit\r\n if (orgUnitId) {\r\n const fieldIds = getters.fieldsForCurrentOrgUnit.map(x => x.id)\r\n const visibleOnly = getters.entityLookup[orgUnitId].visibleOnly\r\n\r\n return Promise.all([\r\n dispatch('loadBasicFieldData', fieldIds),\r\n Promise.all([\r\n visibleOnly ? null : dispatch('mapManagement/loadAvailableZoneMapInfosForOrgUnitId', orgUnitId),\r\n dispatch('reloadFieldCultivationInfoForOrgUnit'),\r\n dispatch('masterData/reloadCustomProducts', {orgUnitId}, {root: true}) // TODO load directly where used, in FrsProductPicker and various views like action list or map details\r\n ])\r\n ])\r\n }\r\n}\r\n\r\nexport const selectOrgUnit = ({state, getters, commit, dispatch}, orgUnitId) => {\r\n if (orgUnitId && !getters['navigation/entityLookup'][orgUnitId]) {\r\n throw new Error(`invalid orgUnitId '${orgUnitId}', not found in current tree`)\r\n }\r\n\r\n const previousOrgUnitId = state.navigation.location.orgUnitId\r\n\r\n commit('navigation/selectOrgUnit', orgUnitId)\r\n\r\n const view = state.ui.view.right\r\n\r\n if (!previousOrgUnitId) {\r\n if (orgUnitId && view in state.ui.transitions.escape) {\r\n commit('setRightView', state.ui.transitions.escape[view])\r\n }\r\n } else {\r\n const nextView = orgUnitId && view in state.ui.transitions.orgUnit\r\n ? state.ui.transitions.orgUnit[view]\r\n : 'default'\r\n\r\n commit('setRightView', nextView)\r\n }\r\n\r\n return Promise.all([\r\n dispatch('reloadOrgUnitData'),\r\n dispatch('loadLotsOfOrgUnitData', {skipFocus: false})\r\n ])\r\n}\r\n\r\nexport const selectField = ({state, getters, commit, dispatch}, fieldId) => {\r\n if (!fieldId) {\r\n throw new Error('selectField action called without field')\r\n }\r\n if (!getters['navigation/entityLookup'][fieldId]) {\r\n throw new Error(`invalid fieldId '${fieldId}', not found in current tree`)\r\n }\r\n\r\n const {fieldId: previousFieldId} = state.navigation.location\r\n const parentLookup = getters['navigation/parentLookup']\r\n\r\n commit('navigation/selectField', {fieldId, parentLookup})\r\n\r\n const view = state.ui.view.right\r\n\r\n if (previousFieldId) {\r\n if (fieldId && view in state.ui.transitions.escape) {\r\n commit('setRightView', state.ui.transitions.escape[view])\r\n }\r\n } else {\r\n const nextView = fieldId && view in state.ui.transitions.field\r\n ? state.ui.transitions.field[view]\r\n : 'default'\r\n\r\n commit('setRightView', nextView)\r\n }\r\n\r\n const feature = getters.fieldFeature\r\n\r\n if (feature) {\r\n return dispatch('map/focus', feature)\r\n }\r\n}\r\n\r\nexport const selectGroup = ({commit, dispatch}, tag) => {\r\n commit('navigation/selectTag', tag)\r\n return dispatch('loadGeometriesForTag')\r\n}\r\n","export const showCultivationPlan = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'cultivationPlan', {root: true})\r\n}\r\n\r\nexport const cultivationPlanningOrgUnit = ({dispatch, commit}, {cultivationId, fieldId}) => {\r\n dispatch('fieldRecordSystem/cultivationPlanning/editCultivationOrgUnit', {cultivationId: cultivationId, fieldId: fieldId}, {root: true})\r\n if (cultivationId) {\r\n commit('fieldRecordSystem/setRightView', 'editCultivationPlanningOrgUnit', {root: true})\r\n } else {\r\n commit('fieldRecordSystem/setRightView', 'cultivationPlanningOrgUnit', {root: true})\r\n }\r\n}\r\n\r\nexport const showActionOverview = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'actionOverview', {root: true})\r\n}\r\n\r\nexport const showAnnualPlan = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'annualPlan', {root: true})\r\n}\r\n\r\nexport const showAnnualPlanDiff = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'annualPlanDiff', {root: true})\r\n}\r\n\r\nexport const showCropRotation = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'cropRotation', {root: true})\r\n}\r\n\r\nexport const showMachinesOverview = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'machinesOverview', {root: true})\r\n}\r\n\r\nexport const showPersonsOverview = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'personsOverview', {root: true})\r\n}\r\n\r\nexport const showCompanyNumbers = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'companyNumbers', {root: true})\r\n}\r\n\r\nexport const showCompanyLanePlans = ({commit, dispatch}) => {\r\n commit('fieldRecordSystem/setRightView', 'lanePlanSelectionOrgUnit', {root: true})\r\n}\r\n\r\nexport const showDefaultYield = ({commit}) => {\r\n commit('fieldRecordSystem/setRightView', 'defaultYields', {root: true})\r\n}\r\n","import axios from 'axios'\r\nimport {smarterGet} from 'src/js/helpers/vuex/data-loading'\r\nimport {can} from 'src/js/helpers/permissions'\r\n\r\n// root\r\nexport const addCropRotation = ({state, commit}, cropRotation) => {\r\n const orgUnitId = state.navigation.location.orgUnitId\r\n return axios.post(`/api/v2/entities/orgunits/${orgUnitId}/crop-rotations`, cropRotation)\r\n .then((request) => request.data)\r\n .then((id) => {\r\n cropRotation.id = id\r\n commit('addCropRotation', cropRotation)\r\n })\r\n}\r\n\r\nexport const updateCropRotation = ({state, commit}, cropRotation) => {\r\n const orgUnitId = state.navigation.location.orgUnitId\r\n return axios.post(`/api/v2/entities/orgunits/${orgUnitId}/crop-rotations`, cropRotation)\r\n .then((request) => request.data)\r\n .then(() => {\r\n if (state.navigation.location.orgUnitId === orgUnitId) {\r\n commit('updateCropRotation', cropRotation)\r\n }\r\n })\r\n}\r\n\r\nexport const deleteCropRotation = ({state, commit}, {id}) => {\r\n const orgUnitId = state.navigation.location.orgUnitId\r\n return axios.delete(`/api/v2/entities/orgunits/${orgUnitId}/crop-rotations/${id}`)\r\n .then(() => {\r\n commit('removeCropRotation', id)\r\n })\r\n}\r\n\r\nexport const reloadCropRotations = ({commit, getters, rootState}) => {\r\n const rootOrgUnitId = getters['navigation/rootOrgUnitId']\r\n\r\n if (!rootOrgUnitId) return\r\n\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return smarterGet([\r\n '/api/v2/entities/orgunits/{rootId}/crop-rotations'\r\n ], {\r\n id: 'reload.cropRotation',\r\n expiry: 120,\r\n inputs: {\r\n rootId: () => rootOrgUnitId\r\n },\r\n sharedCache: true,\r\n onResult ([rootRotations]) {\r\n if (getters['navigation/rootOrgUnitId'] === rootOrgUnitId) {\r\n commit('setRootCropRotations', rootRotations)\r\n }\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\n// reloads the assigned crop rotations when user navigates to different org unit\r\nexport const reloadAssignedCropRotations = ({state, commit, rootState}) => {\r\n const orgUnitId = state.navigation.location.orgUnitId\r\n\r\n if (!orgUnitId) return\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return smarterGet([\r\n '/api/v2/entities/orgunits/{orgUnitId}/crop-rotations/active'\r\n ], {\r\n id: 'reload.cropRotation.assigned',\r\n expiry: 120,\r\n inputs: {\r\n orgUnitId: () => orgUnitId\r\n },\r\n sharedCache: true,\r\n onResult ([assignedRotations]) {\r\n if (state.navigation.location.orgUnitId === orgUnitId) {\r\n commit('setAssignedCropRotationsForOrgUnit', assignedRotations)\r\n }\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport const saveAssignedCropRotations = ({state, commit}, cropRotations) => {\r\n // maybe add \"hasChanges\" flag somewhere later and set to false on resolve\r\n const orgUnitId = state.navigation.location.orgUnitId\r\n return axios.put(`/api/v2/entities/orgunits/${orgUnitId}/crop-rotations/active`, cropRotations.map(x => x.id))\r\n .then(() => {\r\n if (state.navigation.location.orgUnitId === orgUnitId) {\r\n commit('setAssignedCropRotationsForOrgUnit', cropRotations)\r\n }\r\n })\r\n}\r\n","export const lookup = (objects, keyFunction, valueFunction = x => x) => {\r\n const lookup = {}\r\n objects.forEach(x => {\r\n lookup[keyFunction(x)] = valueFunction(x)\r\n })\r\n return lookup\r\n}\r\n\r\nexport const groupBy = (objects, keyFunction, valueFunction = x => x) => {\r\n const grouped = {}\r\n objects.forEach(x => {\r\n const key = keyFunction(x)\r\n if (!(key in grouped)) {\r\n grouped[key] = []\r\n }\r\n grouped[key].push(valueFunction(x))\r\n })\r\n return grouped\r\n}\r\n\r\nexport const idLookup = (objects, valueFunction = x => x) => lookup(objects, x => x.id, valueFunction)\r\n\r\nexport const parametricReducers = {\r\n lookup: (keyFunction, valueFunction = x => x) => (lookup, obj) => {\r\n lookup = lookup || {}\r\n lookup[obj.id] = valueFunction(obj)\r\n return lookup\r\n }\r\n}\r\n\r\nexport const reducers = {\r\n\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\nimport {can} from 'src/js/helpers/permissions'\r\n\r\n// eslint-disable-next-line import/no-webpack-loader-syntax\r\nimport ProcessFieldWktsWorker from 'workerize-loader?inline=true!./process-field-wkts.worker'\r\n\r\nconst worker = new ProcessFieldWktsWorker()\r\n\r\nasync function processFieldWkts (wktByFieldId) {\r\n const result = await worker.processFieldWkts(wktByFieldId)\r\n\r\n for (const fieldId in result) {\r\n result[fieldId].wkt = wktByFieldId[fieldId]\r\n }\r\n\r\n return result\r\n}\r\n\r\nexport async function processFieldWkt (wkt) {\r\n const result = await worker.processFieldWkts({[null]: wkt})\r\n\r\n const partialFieldData = {\r\n wkt,\r\n ...result[null]\r\n }\r\n\r\n return partialFieldData\r\n}\r\n\r\nexport function startEditingField ({dispatch, getters}) {\r\n if (!getters.fieldId) return\r\n\r\n const features = getters.fieldFeature\r\n ? [getters.fieldFeature]\r\n : []\r\n\r\n return dispatch('map/startQuickMode', features)\r\n}\r\n\r\nexport function getCultivationUpdateCandidates ({state, getters, commit, rootState}) {\r\n const fieldId = getters.fieldId\r\n const harvestYear = state.userSettings.harvestYear\r\n\r\n const url = `/api/v2/entities/fields/${fieldId}/${harvestYear}/cultivations/geo-update-candidates`\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return axios.get(url).then(response => response.data)\r\n .then(cultivations => {\r\n commit('updateFieldData', {[fieldId]: {futureCultivations: cultivations}})\r\n\r\n return cultivations.length > 0\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport async function saveFieldGeometry ({state, commit, dispatch, rootState}, {wkt, cultivationIds}) {\r\n const {fieldId} = state.navigation.location\r\n const {harvestYear} = state.userSettings\r\n\r\n const geometry = wkt\r\n const cultivationUpdates = cultivationIds.map(cultivationId => axios.post(`/api/v2/cultivations/${cultivationId}/geometry`, {geometry}))\r\n const serverContext = state.data.field[fieldId].context\r\n\r\n const context = {\r\n ...serverContext,\r\n fieldId,\r\n payload: {geometry, id: fieldId}\r\n }\r\n\r\n dispatch('reloadWeatherData')\r\n\r\n await Promise.all([\r\n ...cultivationUpdates,\r\n axios.post(`/api/v2/entities/fields/geodata/${harvestYear}`, context)\r\n ])\r\n\r\n // module reloading geometries needs to invalidate the cache\r\n commit('dataLoading/invalidate', 'orgUnit.simplified-geometries', {root: true})\r\n commit('dataLoading/invalidate', 'orgUnit.geometries', {root: true})\r\n commit('dataLoading/invalidate', 'harvestYear.fullFieldData', {root: true})\r\n\r\n // NOTE no await on purpose, no real need to wait for reload of the purely visual geometries\r\n dispatch('navigation/loadSimplifiedFieldGeometriesForCurrentOrgUnit')\r\n\r\n const wktsByFieldId = {[fieldId]: geometry}\r\n const fieldDataLookup = await processFieldWkts(wktsByFieldId)\r\n commit('updateFieldData', fieldDataLookup)\r\n\r\n for (const cultivationId of cultivationIds) {\r\n commit('cultivation/updateCultivationGeometry', {cultivationId, geometry})\r\n }\r\n\r\n // NOTE probably for recalculated area?\r\n // NOTE workaround for history context as well\r\n await dispatch('loadFullFieldData', fieldId)\r\n}\r\n\r\nconst transformToFieldData = wktByFieldId => Object.keys(wktByFieldId)\r\n .reduce((fieldData, fieldId) => Object.assign(fieldData, {[fieldId]: {wkt: wktByFieldId[fieldId]}}), {})\r\n\r\nexport const loadGeometriesForTag = ({state, commit}) => {\r\n const {tag} = state.navigation.location\r\n const {harvestYear} = state.userSettings\r\n\r\n return axios.get(`/api/v2/settings/tags/${tag}/fields/geodata/${harvestYear}`)\r\n .then(response => response.data)\r\n .then(wktByFieldId => {\r\n commit('updateFieldData', transformToFieldData(wktByFieldId))\r\n })\r\n}\r\n\r\nexport function loadFieldGeometriesForCurrentOrgUnit ({state, getters, commit, rootState}) {\r\n if (!state.navigation.location.orgUnitId) return\r\n const visibleOnly = getters.entityLookup[state.navigation.location.orgUnitId].visibleOnly\r\n if (visibleOnly) return\r\n\r\n return smarterGet('/api/v2/entities/orgunits/{orgUnitId}/fields/geodata/{harvestYear}', {\r\n id: 'orgUnit.geometries',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => state.navigation.location.orgUnitId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n async onResult (wktByFieldId) {\r\n const fieldDataLookup = await processFieldWkts(wktByFieldId)\r\n commit('updateFieldData', fieldDataLookup)\r\n },\r\n subtreeInclusive: true\r\n })\r\n}\r\n\r\nexport async function updateFieldGeometry ({commit}, {fieldId, wkt}) {\r\n const wktByFieldId = {[fieldId]: wkt}\r\n const fieldDataLookup = await processFieldWkts(wktByFieldId)\r\n\r\n commit('updateFieldData', fieldDataLookup)\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {can} from '@helpers/permissions'\r\nimport {lookup} from '@helpers/data-transformation'\r\nimport {smarterGet, smarterPost} from '@helpers/vuex/data-loading'\r\nimport {processFieldWkt} from './field-geometries'\r\n\r\nexport async function loadBasicFieldData ({state, commit}, fieldIds) {\r\n const fieldData = await smarterPost('/api/v2/frs/{harvestYear}/fields/data/basic', fieldIds, {\r\n inputs: {\r\n harvestYear: () => state.userSettings.harvestYear\r\n },\r\n id: 'entity.field.data.basic'\r\n })\r\n\r\n if (fieldData) {\r\n const fieldDataLookup = lookup(fieldData, d => d.entityId)\r\n\r\n commit('updateFieldData', fieldDataLookup)\r\n } else {\r\n console.error('[loadBasicFieldData] was called multiple times, some calls were ignored')\r\n }\r\n}\r\n\r\nexport const loadFullFieldData = ({state, commit}, fieldId) => {\r\n return smarterGet('/api/v2/frs/{harvestYear}/fields/{fieldId}/data',\r\n {\r\n id: 'harvestYear.fullFieldData',\r\n expiry: 120,\r\n inputs: {\r\n harvestYear: () => state.userSettings.harvestYear,\r\n fieldId: () => fieldId\r\n },\r\n // NOTE sharedCache is only necessary because of cropRotation, fieldData itself is not shared\r\n sharedCache: true,\r\n async onResult (fieldData) {\r\n const cropRotation = state.cropRotations.company.find(cr => cr.id === fieldData.cropRotationId)\r\n commit('assignCropRotationToField', cropRotation)\r\n\r\n const additionalFieldData = await processFieldWkt(fieldData.geometry)\r\n Object.assign(fieldData, additionalFieldData)\r\n\r\n const fieldDataLookup = lookup([fieldData], d => d.entityId)\r\n\r\n commit('updateFieldData', fieldDataLookup)\r\n }\r\n })\r\n}\r\n\r\nexport async function createNewOrgUnit ({state, commit, dispatch}, {name}) {\r\n const parentId = state.navigation.location.orgUnitId\r\n\r\n if (!name) {\r\n throw new Error('empty orgUnit name is invalid')\r\n }\r\n\r\n const url = parentId\r\n ? `/api/v2/entities/${parentId}/orgunits?name=${encodeURIComponent(name)}`\r\n : `/api/v2/entities/orgunits?name=${encodeURIComponent(name)}`\r\n\r\n const entity = (await axios.post(url)).data\r\n entity.children = [] // TODO find out why server doesn't send this\r\n\r\n if (!parentId) {\r\n await dispatch('reloadEntities')\r\n } else {\r\n await dispatch('navigation/addEntity', {entity, orgUnitId: parentId})\r\n }\r\n commit('setRightView', 'default')\r\n\r\n return entity.id // continuation in CompanyData.vue relies on the created orgUnitId from the server\r\n}\r\n\r\nexport async function deleteOrgUnit ({state, dispatch, getters}) {\r\n const {orgUnitId} = state.navigation.location\r\n\r\n await axios.delete(`/api/v2/entities/${orgUnitId}`)\r\n await dispatch('navigation/removeEntity', orgUnitId)\r\n}\r\n\r\nexport async function updateOrgUnitName ({dispatch, getters}, {orgUnitId, name}) {\r\n if (!name) {\r\n throw new Error('empty orgUnit name is invalid')\r\n }\r\n\r\n const originalName = getters.entityLookup[orgUnitId].name\r\n await dispatch('navigation/renameEntity', {entityId: orgUnitId, name})\r\n\r\n try {\r\n await axios.put(`/api/v2/entities/${orgUnitId}/name?name=${encodeURIComponent(name)}`)\r\n } catch (error) {\r\n console.error(error)\r\n await dispatch('navigation/renameEntity', {entityId: orgUnitId, name: originalName})\r\n }\r\n}\r\n\r\n// TODO check if used, and if it works with history\r\nexport async function createNewField ({state, dispatch}, {name, wkt}) {\r\n const {orgUnitId} = state.navigation.location\r\n\r\n const entity = (await axios.post(`/api/v2/entities/${orgUnitId}/fields`, {name, wkt})).data\r\n\r\n await Promise.all([\r\n dispatch('navigation/addEntity', {entity, orgUnitId}),\r\n dispatch('updateFieldGeometry', {fieldId: entity.id, wkt}),\r\n dispatch('loadBasicFieldData', [entity.id])\r\n ])\r\n}\r\n\r\nexport async function deleteField ({state, commit, dispatch, rootState}) {\r\n const {fieldId} = state.navigation.location\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n\r\n const context = rootState.fieldRecordSystem.data.field[fieldId].context\r\n context.payload = null\r\n\r\n try {\r\n await axios.post(`/api/v2/frs/${harvestYear}/fields/delete`, context)\r\n await dispatch('navigation/removeEntity', fieldId)\r\n commit('dataLoading/invalidate', 'harvestYear.fullFieldData', {root: true})\r\n } catch (error) {\r\n throw error\r\n }\r\n}\r\nexport async function saveCompanyData ({state, commit}, {companyData, orgUnitId}) {\r\n commit('setDataLoading', true)\r\n\r\n try {\r\n const orgUnitData = state.data.orgUnits.data\r\n const existingCompanyData = orgUnitId && orgUnitData[orgUnitId] && orgUnitData[orgUnitId].companyData\r\n\r\n if (!existingCompanyData) {\r\n await axios.put(`/api/v2/entities/orgunits/${orgUnitId}/data/company`)\r\n commit('addEmptyMasterData', orgUnitId)\r\n }\r\n\r\n await axios.put(`/api/v2/entities/orgunits/${orgUnitId}/data/company/info`, companyData)\r\n\r\n commit('updateOrgUnitData', {[orgUnitId]: {companyData}})\r\n commit('setRightView', 'default')\r\n } finally {\r\n commit('setDataLoading', false)\r\n }\r\n}\r\n\r\nexport async function loadMasterData ({commit}, orgUnitId) {\r\n const [{data: companyData}, {data: companyNumbers}] = await Promise.all([\r\n axios.get(`/api/v2/entities/orgunits/${orgUnitId}/data/company/info`),\r\n axios.get(`/api/v2/entities/orgunits/${orgUnitId}/data/company/identification-numbers`)\r\n ])\r\n\r\n commit('updateOrgUnitData', {[orgUnitId]: {companyData: companyData || null, companyNumbers}}) // NOTE server returns 204 with empty string body instead of null if no company data exists\r\n}\r\n\r\nexport async function updateCompanyNumber ({state, commit}, companyNumber) {\r\n commit('setDataLoading', true)\r\n const {orgUnitId} = state.navigation.location\r\n try {\r\n const response = await axios.post(`/api/v2/entities/orgunits/${orgUnitId}/data/company/identification-numbers`, companyNumber)\r\n\r\n if (!companyNumber.id) {\r\n companyNumber = response.data\r\n }\r\n\r\n commit('updateCompanyNumber', {orgUnitId, companyNumber})\r\n } finally {\r\n commit('setDataLoading', false)\r\n }\r\n}\r\n\r\nexport async function removeCompanyNumber ({state, commit}, companyNumber) {\r\n commit('setDataLoading', true)\r\n\r\n const {orgUnitId} = state.navigation.location\r\n\r\n try {\r\n await axios.delete(`/api/v2/entities/orgunits/${orgUnitId}/data/company/identification-numbers/${companyNumber.id}`)\r\n\r\n commit('removeCompanyNumber', {orgUnitId, companyNumberId: companyNumber.id})\r\n } finally {\r\n commit('setDataLoading', false)\r\n }\r\n}\r\n\r\nexport async function deleteMasterData ({state, commit}) {\r\n commit('setDataLoading', true)\r\n\r\n const {orgUnitId} = state.navigation.location\r\n\r\n try {\r\n await axios.delete(`/api/v2/entities/orgunits/${orgUnitId}/data/company`)\r\n\r\n commit('deleteMasterData', orgUnitId)\r\n commit('setRightView', 'default')\r\n } finally {\r\n commit('setDataLoading', false)\r\n }\r\n}\r\n\r\nexport const saveRestructuredOrgTree = ({dispatch}, changeList) => {\r\n return axios.post('/api/v2/entities/moveEntities', changeList)\r\n .then(() => dispatch('reloadEntities'))\r\n}\r\n\r\nexport const loadDataForActions = ({dispatch}) => {\r\n return Promise.all([\r\n dispatch('action/loadActionsForOrgUnit'),\r\n dispatch('machines/loadMachines'),\r\n dispatch('persons/loadPersons')\r\n ])\r\n .then(([actions]) => actions)\r\n}\r\n\r\nexport function reloadFieldCultivationInfoForOrgUnit ({commit, rootGetters, rootState}) {\r\n const orgUnit = rootGetters['fieldRecordSystem/orgUnit']\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations') && !orgUnit.visibleOnly) {\r\n return smarterGet('/api/v2/{harvestYear}/org/{orgUnitId}/cultivation-info', {\r\n id: 'orgUnit.fieldCultivationInfo',\r\n expiry: 10,\r\n inputs: {\r\n orgUnitId: () => rootState.fieldRecordSystem.navigation.location.orgUnitId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n sharedCache: true, // NOTE only required because of the clearing loop below\r\n onResult (cultivationInfoByFieldId) {\r\n for (const id in cultivationInfoByFieldId) {\r\n cultivationInfoByFieldId[id] = {cultivationInfo: cultivationInfoByFieldId[id]}\r\n }\r\n // NOTE this necessitates the `sharedCache` flag\r\n for (const field of rootGetters['fieldRecordSystem/fieldsForCurrentOrgUnit']) {\r\n if (!cultivationInfoByFieldId[field.id]) {\r\n cultivationInfoByFieldId[field.id] = {cultivationInfo: null}\r\n }\r\n }\r\n commit('fieldRecordSystem/updateFieldData', cultivationInfoByFieldId, {root: true})\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nexport const setHarvestYear = ({state, commit, dispatch}, harvestYear) => {\r\n if (harvestYear !== state.userSettings.harvestYear) {\r\n // optimistic updating\r\n const previous = state.userSettings.harvestYear\r\n commit('setUserSettings', {harvestYear})\r\n\r\n return axios.put(`/api/v2/settings/harvest-year/${harvestYear}`)\r\n .catch(() => {\r\n commit('setUserSettings', {harvestYear: previous})\r\n })\r\n }\r\n}\r\n\r\nexport const setFabCollapsed = ({state, commit}, fabCollapsed) => {\r\n if (fabCollapsed !== state.userSettings.fabCollapsed) {\r\n // optimistic updating\r\n // const previous = state.userSettings.fabCollapsed\r\n commit('setUserSettings', {fabCollapsed})\r\n\r\n // For testing\r\n\r\n // const url = '/api/v2/settings/show-field-codes'\r\n //\r\n // const method = fabCollapsed ? axios.put : axios.delete\r\n //\r\n // return method(url)\r\n // .catch(() => {\r\n // commit('setUserSettings', {fabCollapsed: previous})\r\n // })\r\n }\r\n}\r\n\r\nexport const setFieldTags = ({state, commit}, {id, tags}) => {\r\n const previous = state.userSettings.tags.fields[id]\r\n\r\n commit('setFieldTags', {id, tags})\r\n\r\n return axios.put(`/api/v2/settings/tags/fields/${id}`, tags)\r\n .catch(() => {\r\n commit('setFieldTags', {id, tags: previous})\r\n })\r\n}\r\n\r\nexport const toggleFavorited = ({state, commit}, {id, type}) => {\r\n // optimistic updating\r\n const previous = state.userSettings.favorites[type].includes(id)\r\n const favorited = !previous\r\n\r\n commit('setFavoriteState', {id, favorited, type})\r\n\r\n const method = favorited\r\n ? axios.put\r\n : axios.delete\r\n\r\n const routeLookup = {\r\n cropUsages: 'crop-usages'\r\n }\r\n\r\n return method(`/api/v2/settings/favorites/${routeLookup[type] || type}/${id}`)\r\n .catch(() => {\r\n commit('setFavoriteState', {id, favorited: previous, type})\r\n })\r\n}\r\n\r\nexport const loadUserSettings = ({commit}) => {\r\n return axios.get('/api/v2/settings')\r\n .then(response => response.data)\r\n .then(settings => {\r\n for (const key in settings.ui) {\r\n commit('setUserUiSettings', {flag: key, value: settings.ui[key]})\r\n }\r\n commit('setUserSettings', settings)\r\n })\r\n}\r\n\r\nexport function loadUserPermissions ({commit}) {\r\n return axios.get('/api/v2/permissions')\r\n .then(response => {\r\n commit('setUserPermissions', response.data, {root: true})\r\n })\r\n}\r\n\r\nexport const setUiFlag = ({commit}, {flag, value}) => {\r\n commit('setUserUiSettings', {flag, value})\r\n\r\n const url = `/api/v2/settings/ui/${flag}`\r\n\r\n return value\r\n ? axios.put(url)\r\n : axios.delete(url)\r\n}\r\n","import axios from 'axios'\r\nimport moment from 'moment'\r\nimport centroid from '@turf/centroid'\r\nimport groupBy from 'lodash/groupBy'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport const loadWeatherData = ({state, commit, rootState}, fieldId) => {\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const promise = state.data.field[fieldId].geometry\r\n ? Promise.resolve(state.data.field[fieldId].geometry)\r\n : axios.get(`/api/v2/entities/fields/${fieldId}/geodata/${harvestYear}`).then(response => response.data)\r\n\r\n return promise.then(geometry => {\r\n if (!geometry) return\r\n const centroidCoordinates = centroid(geometry)\r\n return getWeatherData(centroidCoordinates.geometry.coordinates)\r\n .then(climate => {\r\n commit('updateFieldData', {[fieldId]: {climate}})\r\n })\r\n })\r\n}\r\n\r\n/*\r\nWeather API Parameter:\r\n Temperature = 0,\r\n TemperatureSurface = 1,\r\n DewpointTemperature = 2,\r\n RelativeHumidity = 3,\r\n TotalPrecipitation = 4,\r\n U = 5,\r\n V = 6,\r\n Pressure = 7,\r\n DownwardShortWaveRadiation = 8,\r\n UpwardLongWaveRadiation = 9,\r\n TotalCloudCover = 10,\r\n LowCloudCover = 11,\r\n MediumCloudCover = 12,\r\n HighCloudCover = 13\r\n*/\r\n\r\nexport function getWeatherData (centroid) {\r\n const startDate = moment.utc().add(-3, 'days').startOf('day').toISOString()\r\n const endDate = moment.utc().add(3, 'days').endOf('day').toISOString()\r\n const data = retrieveWeatherData(startDate, endDate, centroid)\r\n return data\r\n}\r\n\r\nconst retrieveWeatherData = (startDate, endDate, centroid) => {\r\n const parameterNames = ['temperature', 'humidity', 'precipitation', 'totalCloudCover']\r\n const validTypes = [0, 3, 4, 10]\r\n\r\n const transformWeatherData = data => {\r\n const getDateString = x => {\r\n const date = moment(x.date)\r\n return `${date.year()}-0${date.month() + 1}-${date.date()}`\r\n }\r\n const entriesByDay = groupBy(data, getDateString)\r\n const weatherData = {}\r\n\r\n for (const day in entriesByDay) {\r\n const entriesByHour = groupBy(entriesByDay[day], x => x.date)\r\n\r\n weatherData[day] = Object.keys(entriesByHour).map(timestamp => {\r\n const dataForHour = {timestamp}\r\n\r\n validTypes.forEach(type => {\r\n const entry = entriesByHour[timestamp].find(x => x.type === type)\r\n\r\n dataForHour[parameterIdToName(type)] = entry ? entry.value : null\r\n })\r\n\r\n if (dataForHour.temperature) {\r\n dataForHour.temperature -= 273.15 // conversion from Kelvin to Celsius\r\n }\r\n\r\n return dataForHour\r\n })\r\n }\r\n\r\n return weatherData\r\n }\r\n\r\n return axios.get(buildUrl(parameterNames, startDate, endDate, centroid))\r\n .then(res => res.data)\r\n .then(transformWeatherData)\r\n}\r\n\r\nconst buildUrl = (parameterNames, startDate, endDate, centroid) => {\r\n const parametersUrl = parameterNames.map(x => `parameters=${parameterNameToId(x)}`).join('&')\r\n return `/api/Climate/GetParameterValues?${parametersUrl}&lat=${centroid[1]}&lon=${centroid[0]}&startDateTime=${startDate}&endDateTime=${endDate}`\r\n}\r\n\r\nconst parameterNameToId = (name) => {\r\n if (name === 'temperature') return 0\r\n if (name === 'humidity') return 3\r\n if (name === 'precipitation') return 4\r\n if (name === 'totalCloudCover') return 10\r\n throw Error('weather parameter name not found')\r\n}\r\n\r\nconst parameterIdToName = (id) => {\r\n if (id === 0) return 'temperature'\r\n if (id === 3) return 'humidity'\r\n if (id === 4) return 'precipitation'\r\n if (id === 10) return 'totalCloudCover'\r\n throw Error('weather parameter id not found')\r\n}\r\n\r\nexport async function getClimateData ({state, rootState, rootGetters, commit}) {\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const geoJson = await axios.get(`/api/v2/entities/fields/${fieldId}/geodata/${harvestYear}`).then(response => response.data)\r\n const centroidCoordinates = centroid(geoJson)\r\n\r\n return smarterGet('/api/v2/weather/data/{lat}/{lon}', {\r\n id: 'climate.data.get',\r\n expiry: 120,\r\n inputs: {\r\n fieldId: () => rootGetters['fieldRecordSystem/fieldId'],\r\n lat: () => centroidCoordinates.geometry.coordinates[1],\r\n lon: () => centroidCoordinates.geometry.coordinates[0]\r\n },\r\n onResult (monthlyClimateData) {\r\n commit('updateFieldData', {[fieldId]: {monthlyClimateData}})\r\n }\r\n })\r\n}\r\n","export * from './view-data-loading'\r\nexport * from './master-data-loading'\r\nexport * from './navigation'\r\nexport * from './navigation-actions'\r\nexport * from './crop-rotations'\r\nexport * from './entity'\r\nexport * from './field-geometries'\r\nexport * from './user-data'\r\nexport * from './weather'\r\n\r\nexport const displayCultivationsForField = ({commit}) => {\r\n commit('setRightView', 'cultivationsDisplayField')\r\n}\r\n\r\nexport const displayActionsForField = ({commit}) => {\r\n commit('setRightView', 'actionDisplayField')\r\n}\r\n","import {filters} from '@helpers/tree'\r\nimport {geoJsonFormat} from '@helpers/openlayers/features'\r\nimport {fromFields} from '@frs/helpers/geojson/create-features'\r\n\r\nimport workflows from './mutations/workflows'\r\n\r\nexport const root = (state, getters) => getters['navigation/entityLookup'][getters['navigation/rootOrgUnitId']]\r\n\r\nexport function harvestYear (state) {\r\n return state.userSettings.harvestYear\r\n}\r\n\r\nexport function fieldId (state) {\r\n return state.navigation.location.fieldId\r\n}\r\n\r\nexport function field (state, getters) {\r\n return getters['navigation/entityLookup'][getters.fieldId]\r\n}\r\n\r\nexport function fieldName (state, getters) {\r\n const fieldId = state.navigation.location.fieldId\r\n return getters.entityNameLookup[fieldId]\r\n}\r\n\r\nexport function fieldWkt (state, getters) {\r\n return getters.fieldId ? state.data.field[getters.fieldId].wkt : null\r\n}\r\n\r\nexport function fieldFeature (state, getters) {\r\n if (!getters.fieldId) return null\r\n\r\n const field = getters.entityLookup[getters.fieldId]\r\n\r\n const feature = fromFields([field], state.data.field)[0]\r\n\r\n if (!feature || !feature.geometry) return null\r\n\r\n return geoJsonFormat.readFeature(feature)\r\n}\r\n\r\nexport function fieldWktsFromOrgUnit (state, getters) {\r\n let fields = getters['navigation/subTreeFields']\r\n\r\n fields = fields.map(x => ({\r\n id: x.id,\r\n name: x.name\r\n }))\r\n const fieldWkts = []\r\n for (let field of fields) {\r\n let details = state.data.field[field.id]\r\n fieldWkts.push({id: field.id, name: field.name, wkt: details.wkt})\r\n }\r\n return fieldWkts.filter(x => x.wkt)\r\n}\r\n\r\nexport function orgUnitId (state) {\r\n return state.navigation.location.orgUnitId\r\n}\r\n\r\nexport function orgUnit (state, getters) {\r\n return getters.orgUnitId ? getters['navigation/entityLookup'][getters.orgUnitId] : null\r\n}\r\n\r\nexport function orgUnitName (state, getters) {\r\n return getters.orgUnit ? getters.orgUnit.name : null\r\n}\r\n\r\nexport function rootOrgUnitId (state, getters) {\r\n return getters['navigation/rootOrgUnitId']\r\n}\r\n\r\n// TODO remove after usages are migrated to navigation module\r\nexport const allEntities = (state, getters) => getters['navigation/entities']\r\n// TODO remove after usages are migrated to navigation module\r\nexport const entityLookup = (state, getters) => getters['navigation/entityLookup']\r\n// TODO remove after usages are migrated to navigation module\r\nexport const allFields = (state, getters) => getters.allEntities.filter(filters.fields)\r\n\r\nexport const entityNameLookup = (state, getters) => {\r\n const lookup = {}\r\n getters.allEntities.forEach(entity => {\r\n lookup[entity.id] = entity.name\r\n })\r\n return lookup\r\n}\r\n\r\nexport const fieldsForCurrentOrgUnit = (state, getters) => getters['navigation/subTreeFields']\r\n\r\nexport const entitiesForSelectedOrgUnit = (state, getters) => getters['navigation/flattenedSubTree']\r\n\r\nexport const fieldsForSelectedOrgUnit = (state, getters) => getters['navigation/subTreeFields']\r\nexport const orgUnitsForSelectedOrgUnit = (state, getters) => getters['navigation/subTreeOrgUnits']\r\n\r\nconst invertLookup = lookup => {\r\n const inverted = {}\r\n for (const key in lookup) {\r\n for (const value of lookup[key]) {\r\n if (!inverted[value]) {\r\n inverted[value] = []\r\n }\r\n inverted[value].push(key)\r\n }\r\n }\r\n return inverted\r\n}\r\n\r\nexport const allFieldIdsByTag = state => {\r\n return invertLookup(state.userSettings.tags.fields)\r\n}\r\n\r\nexport const fieldIdsForSelectedOrgUnitByTag = (state, getters) => {\r\n const filteredLookup = {}\r\n getters.fieldsForSelectedOrgUnit.map(field => {\r\n var tags = state.userSettings.tags.fields[field.id]\r\n if (tags) {\r\n filteredLookup[field.id] = tags\r\n }\r\n })\r\n return invertLookup(filteredLookup)\r\n}\r\n\r\nexport const fieldIdsForCurrentOrgUnitByTag = (state, getters) => {\r\n const filteredLookup = {}\r\n getters.fieldsForCurrentOrgUnit.map(field => {\r\n var tags = state.userSettings.tags.fields[field.id]\r\n if (tags) {\r\n filteredLookup[field.id] = tags\r\n }\r\n })\r\n return invertLookup(filteredLookup)\r\n}\r\n\r\nexport const existingTags = (state, getters) => [...new Set(Object.keys(getters.allFieldIdsByTag))]\r\n\r\nexport const resolvedView = state => {\r\n const view = state.ui.view.right\r\n if (workflows[view] && workflows[view].alias) {\r\n return workflows[view].alias\r\n }\r\n return view\r\n}\r\n\r\nexport const resolvedBack = state => {\r\n const view = state.ui.transitions.back[state.ui.view.right]\r\n if (workflows[view] && workflows[view].alias) {\r\n return workflows[view].alias\r\n }\r\n return view || 'default'\r\n}\r\n\r\n// TODO use cultivation filter\r\nexport function fieldFeaturesForCurrentOrgUnit (state, getters) {\r\n return fromFields(getters.fieldsForCurrentOrgUnit, state.data.field)\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\nimport {flattenEntityForest, filters} from '@helpers/tree'\r\nimport {lookupById} from '@helpers/reducers'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nconst addHistoryEntry = (state, newLocation) => {\r\n if (Object.keys(newLocation).some(key => newLocation[key] !== state.location[key])) {\r\n state.history.shift({...state.location})\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n entityForest: [], // forest from server\r\n location: {\r\n // rocket & legacy tree\r\n fieldId: null,\r\n orgUnitId: null,\r\n // tag display, should this really be here?\r\n tag: null\r\n },\r\n history: [],\r\n search: {\r\n text: '',\r\n result: null,\r\n searching: false\r\n },\r\n simplifiedGeometries: {}\r\n },\r\n getters: {\r\n entities (state) {\r\n return flattenEntityForest(state.entityForest)\r\n },\r\n subTree (state, getters) {\r\n return state.location.orgUnitId ? getters.entityLookup[state.location.orgUnitId] : null\r\n },\r\n flattenedSubTree (state, getters) {\r\n return getters.subTree ? flattenEntityForest([getters.subTree]) : []\r\n },\r\n subTreeOrgUnits (state, getters) {\r\n return getters.flattenedSubTree.filter(filters.orgUnits)\r\n },\r\n subTreeFields (state, getters) {\r\n return getters.flattenedSubTree.filter(filters.fields)\r\n },\r\n entityLookup (state, getters) {\r\n return getters.entities.reduce(lookupById, {})\r\n },\r\n parentLookup (state, getters) {\r\n const lookup = {}\r\n getters.entities.filter(filters.orgUnits).forEach(orgUnit => {\r\n orgUnit.children.forEach(child => {\r\n lookup[child.id] = orgUnit.id\r\n })\r\n })\r\n return lookup\r\n },\r\n rootOrgUnitId (state, getters) {\r\n let entity = state.location.orgUnitId\r\n while (getters.parentLookup[entity]) {\r\n entity = getters.parentLookup[entity]\r\n }\r\n return entity\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'searching',\r\n 'fieldId'\r\n ]),\r\n setEntityForest (state, forest) {\r\n state.entityForest = forest\r\n\r\n const lookup = flattenEntityForest(forest).reduce(lookupById, {})\r\n\r\n if (!lookup[state.location.orgUnitId]) {\r\n state.location.orgUnitId = null\r\n state.location.fieldId = null\r\n }\r\n if (!lookup[state.location.fieldId]) {\r\n state.location.fieldId = null\r\n }\r\n },\r\n setEntitySubTree (state, {orgUnitId, subtree, entityLookup}) {\r\n const orgUnit = entityLookup[orgUnitId]\r\n orgUnit.children = subtree.children\r\n },\r\n addEntity (state, {entity, orgUnitId, entityLookup}) {\r\n const parent = entityLookup[orgUnitId]\r\n\r\n if (parent) {\r\n parent.children.push(entity)\r\n } else {\r\n state.entityForest.push(entity)\r\n }\r\n },\r\n removeEntity (state, {entityId, entityLookup, parentLookup}) {\r\n const parentId = parentLookup[entityId]\r\n const parent = entityLookup[parentId]\r\n\r\n if (parent) {\r\n parent.children = parent.children.filter(x => x.id !== entityId)\r\n } else {\r\n state.entityForest = state.entityForest.filter(x => x.id !== entityId)\r\n }\r\n\r\n if (state.location.fieldId === entityId) {\r\n state.location.fieldId = null\r\n }\r\n\r\n if (state.location.orgUnitId === entityId) {\r\n state.location.fieldId = null\r\n state.location.orgUnitId = parentId || null\r\n }\r\n },\r\n renameEntity (state, {entityId, name, entityLookup}) {\r\n entityLookup[entityId].name = name\r\n },\r\n selectOrgUnit (state, orgUnitId) {\r\n const location = {orgUnitId, fieldId: null, tag: null}\r\n addHistoryEntry(state, location)\r\n state.location = location\r\n },\r\n selectField (state, {fieldId, parentLookup}) {\r\n const location = {orgUnitId: parentLookup[fieldId], fieldId, tag: null}\r\n if (!location.orgUnitId) {\r\n throw new Error(`invalid field without parent: ${fieldId}`)\r\n }\r\n addHistoryEntry(state, location)\r\n state.location = location\r\n },\r\n selectTag (state, tag) {\r\n const location = {orgUnitId: null, fieldId: state.location.fieldId, tag}\r\n addHistoryEntry(state, location)\r\n state.location = location\r\n },\r\n setSearchText (state, text) {\r\n state.search.text = text\r\n if (!text) {\r\n state.search.result = null\r\n }\r\n },\r\n setSearchResult (state, result) {\r\n state.search.result = result\r\n },\r\n setSearching (state, flag) {\r\n state.search.searching = flag\r\n },\r\n setSimplifiedGeometries (state, geometries) {\r\n state.simplifiedGeometries = {...state.simplifiedGeometries, ...geometries}\r\n }\r\n },\r\n actions: {\r\n addEntity ({getters, commit}, {entity, orgUnitId}) {\r\n const {entityLookup} = getters\r\n commit('addEntity', {entity, orgUnitId, entityLookup})\r\n },\r\n removeEntity ({getters, commit}, entityId) {\r\n const {entityLookup, parentLookup} = getters\r\n commit('removeEntity', {entityId, entityLookup, parentLookup})\r\n },\r\n renameEntity ({getters, commit}, {entityId, name}) {\r\n const {entityLookup} = getters\r\n commit('renameEntity', {entityId, name, entityLookup})\r\n },\r\n loadSimplifiedFieldGeometriesForCurrentOrgUnit ({state, getters, commit, rootState}) {\r\n if (!state.location.orgUnitId) return\r\n const visibleOnly = getters.entityLookup[state.location.orgUnitId].visibleOnly\r\n if (visibleOnly) {\r\n commit('setSimplifiedGeometries', null)\r\n return\r\n }\r\n\r\n return smarterGet('/api/v2/entities/orgunits/{orgUnitId}/fields/simplified-geodata/{harvestYear}', {\r\n id: 'orgUnit.simplified-geometries',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => state.location.orgUnitId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n async onResult (geometryLookup) {\r\n commit('setSimplifiedGeometries', geometryLookup)\r\n },\r\n subtreeInclusive: true\r\n })\r\n }\r\n }\r\n}\r\n","import {simplify} from '@turf/turf'\r\n\r\nimport {config} from 'src/js/infrastructure'\r\n\r\n// NOTE use only for display purposes where precision is not important and slight discrepancies will not be noticed, e.g. thumbnails\r\nexport function simplifyLowQuality (geojsonGeometry) {\r\n simplify(geojsonGeometry, 0.0001, false, true)\r\n}\r\n\r\nexport function simplifyHighQuality (geojsonGeometry) {\r\n simplify(geojsonGeometry, config.defaultImportSimplificationTolerance, true, true)\r\n}\r\n","import Vue from 'vue'\r\nimport {parse} from 'wellknown'\r\nimport {cloneDeep} from 'lodash'\r\n\r\nimport {simplifyLowQuality} from '@helpers/geojson/simplification'\r\n\r\nconst mutations = {\r\n setEcoTypes (state, types) {\r\n state.data.ecoTypes = types\r\n },\r\n setCultivationTypes (state, types) {\r\n state.data.cultivationTypes = types\r\n },\r\n updateCultivation (state, cultivation) {\r\n Vue.set(state.data.selection.orgUnit, cultivation.id, cultivation)\r\n },\r\n updateCultivationGeometry (state, {cultivationId, geometry: wkt}) {\r\n if (cultivationId in state.data.selection.orgUnit) {\r\n const cultivation = state.data.selection.orgUnit[cultivationId]\r\n const geojsonGeometry = parse(wkt)\r\n cultivation.geometry = wkt\r\n\r\n cultivation.geojsonGeometry = geojsonGeometry\r\n\r\n const simplifiedGeometry = cloneDeep(geojsonGeometry)\r\n // TODO find out why we have cultivations with empty geometries\r\n if (simplifiedGeometry && simplifiedGeometry.coordinates.length) {\r\n simplifyLowQuality(simplifiedGeometry)\r\n }\r\n\r\n cultivation.simplifiedGeometry = simplifiedGeometry\r\n }\r\n },\r\n setCultivationsForField (state, cultivationIds) {\r\n state.data.selection.field = cultivationIds\r\n },\r\n setCultivationsForOrgUnit (state, cultivations) {\r\n state.data.selection.orgUnit = {}\r\n cultivations.forEach(cultivation => {\r\n const geometry = parse(cultivation.geometry)\r\n\r\n cultivation.geojsonGeometry = geometry\r\n\r\n const simplifiedGeometry = cloneDeep(geometry)\r\n // TODO find out why we have cultivations with empty geometries\r\n if (simplifiedGeometry && simplifiedGeometry.coordinates.length) {\r\n simplifyLowQuality(simplifiedGeometry)\r\n }\r\n\r\n cultivation.simplifiedGeometry = simplifiedGeometry\r\n\r\n Vue.set(state.data.selection.orgUnit, cultivation.id, cultivation)\r\n })\r\n\r\n state.data.selection.field = [] // could be changed to just prune invalid ids if necessary\r\n },\r\n deleteCultivation (state, cultivationId) {\r\n state.data.selection.field = state.data.selection.field.filter(id => id !== cultivationId)\r\n Vue.delete(state.data.selection.orgUnit, cultivationId)\r\n },\r\n setPredictedCrop (state, {fieldId, cropUsageId}) {\r\n Vue.set(state.predictedCrops, fieldId, cropUsageId || null)\r\n },\r\n clearPredictedCrop (state, fieldId) {\r\n Vue.delete(state.predictedCrops, fieldId)\r\n },\r\n resetPredictedCrops (state) {\r\n state.predictedCrops = {}\r\n },\r\n setMixtures (state, mixtures) {\r\n state.data.mixtures = mixtures\r\n }\r\n}\r\n\r\nexport default mutations\r\n","import axios from 'axios'\r\nimport moment from 'moment'\r\n\r\nimport {can} from '@helpers/permissions'\r\nimport {getAndCommit} from '@helpers/vuex/actions'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\n// legacy stuff\r\n\r\n// TODO migrate to cultivations@orgunit && refactoring\r\nexport async function saveCultivation ({state, rootState, rootGetters, commit, dispatch}) {\r\n const fieldIds = state.editBuffer.fieldIds.length\r\n ? state.editBuffer.fieldIds\r\n : [rootGetters['fieldRecordSystem/fieldId']]\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n\r\n const geometries = state.editBuffer.geometry\r\n const orgUnit = rootGetters['fieldRecordSystem/orgUnit']\r\n const subTreeOrgUnits = rootGetters['fieldRecordSystem/orgUnitsForSelectedOrgUnit']\r\n\r\n await Promise.all(fieldIds.map(async (fieldId, i) => {\r\n const dto = {\r\n ...state.editBuffer,\r\n geometry: geometries[i],\r\n fieldIds: [fieldId]\r\n }\r\n\r\n if (!state.editBuffer.entityId && !fieldId) {\r\n throw new Error('no way of getting an orgUnitId to save the cultivation')\r\n }\r\n\r\n // NOTE parent of the current field in the loop, cultivation planning can happen for multiple orgs at the same time if started from a parent org\r\n const parentOrgUnitId = state.editBuffer.entityId || subTreeOrgUnits.find(org => org.children.find(child => child.id === fieldId)).id\r\n\r\n const cultivation = (await axios.post(`/api/v2/entities/orgunits/${parentOrgUnitId}/cultivations`, dto)).data\r\n\r\n const fieldsForCultivation = (await axios.get(`/api/v2/entities/orgunits/${orgUnit.id}/cultivations/fields/${harvestYear}`)).data\r\n\r\n if (fieldId) {\r\n const idsForField = [...state.data.selection.field, cultivation.id]\r\n commit('setCultivationsForField', idsForField)\r\n }\r\n\r\n cultivation.fieldIds = fieldsForCultivation[cultivation.id]\r\n\r\n const otherCultivations = Object.values(state.data.selection.orgUnit)\r\n .filter(x => x.id !== cultivation.id)\r\n\r\n commit('setCultivationsForOrgUnit', otherCultivations.concat(cultivation))\r\n }))\r\n}\r\n\r\nexport function displayCultivationOverview ({dispatch}) {\r\n return Promise.all([\r\n dispatch('reloadCultivationsForOrgUnit')\r\n ])\r\n .then(() => {\r\n dispatch('launchCultivationPlanning')\r\n })\r\n}\r\n\r\nexport const launchCultivationPlanning = ({rootState, commit}) => {\r\n commit('editBuffer/reset')\r\n if (rootState.fieldRecordSystem.navigation.location.fieldId) {\r\n commit('fieldRecordSystem/setRightView', 'cultivationsDisplayField', {root: true})\r\n } else {\r\n commit('fieldRecordSystem/setRightView', 'cultivationPlan', {root: true})\r\n }\r\n}\r\n\r\nexport const loadNextCropPredictionForField = ({commit, state, rootState}, fieldId) => {\r\n if (state.predictedCrops[fieldId]) {\r\n // if key exists, field is being toggled off (to unselected state)\r\n commit('clearPredictedCrop', fieldId)\r\n return\r\n }\r\n\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n return axios.get(`/api/v2/entities/fields/${fieldId}/data/crop-usage/next/${harvestYear}`)\r\n .then(response => response.data)\r\n .then(({cropUsageId}) => {\r\n commit('setPredictedCrop', {fieldId, cropUsageId})\r\n })\r\n}\r\n\r\nexport function reloadCultivationsForOrgUnit ({rootState, commit}) {\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return smarterGet([\r\n '/api/v2/entities/orgunits/{orgUnitId}/cultivations/{harvestYear}',\r\n '/api/v2/entities/orgunits/{orgUnitId}/cultivations/fields/{harvestYear}'\r\n ], {\r\n id: 'orgUnit.cultivations',\r\n expiry: 120,\r\n inputs: {\r\n orgUnitId: () => rootState.fieldRecordSystem.navigation.location.orgUnitId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n sharedCache: true,\r\n onResult ([cultivations, fieldsUnderCultivations]) {\r\n cultivations.forEach(cultivation => {\r\n cultivation.fieldIds = fieldsUnderCultivations[cultivation.id]\r\n ? fieldsUnderCultivations[cultivation.id]\r\n : []\r\n })\r\n commit('setCultivationsForOrgUnit', cultivations)\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\n// TODO refactor!\r\n// option 1: pull permission check out and revert to previous getAndCommit usage\r\n// option 2: don't use getAndCommit at all\r\n// option 3: add permission check capabilities to getAndCommit, make sure all usages work\r\nconst reloadCultivationTypesInternal = getAndCommit('/api/v2/masterdata/cultivation/types', 'setCultivationTypes')\r\nexport const reloadCultivationTypes = store => {\r\n if (can(store.rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return reloadCultivationTypesInternal(store)\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\n// TODO refactor!\r\n// option 1: pull permission check out and revert to previous getAndCommit usage\r\n// option 2: don't use getAndCommit at all\r\n// option 3: add permission check capabilities to getAndCommit, make sure all usages work\r\nconst reloadEcoTypesInternal = getAndCommit('/api/v2/masterdata/cultivation/eco/types', 'setEcoTypes')\r\nexport const reloadEcoTypes = store => {\r\n if (can(store.rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return reloadEcoTypesInternal(store)\r\n } else {\r\n return Promise.resolve([])\r\n }\r\n}\r\n\r\nexport const saveQuickCultivation = ({rootState, commit, dispatch}, {cropUsageId, year}) => {\r\n const selectedFieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n const additionalDefaults = {\r\n harvestYears: [year],\r\n geometry: [rootState.fieldRecordSystem.data.field[selectedFieldId].wkt],\r\n dateTimeRange: {\r\n start: moment([year]).startOf('year').toISOString(),\r\n end: moment([year]).endOf('year').toISOString()\r\n },\r\n cropUsageId\r\n }\r\n\r\n commit('editBuffer/reset', additionalDefaults)\r\n return dispatch('saveCultivation')\r\n}\r\n\r\nexport const editCultivationOrgUnit = ({rootState, commit, dispatch, rootGetters}, {cultivationId, fieldId}) => {\r\n // dispatch('editCultivation', cultivationId)\r\n\r\n // action is called when adding a cultivation on org level\r\n\r\n const loadPrerequisiteData = Promise.all([\r\n dispatch('reloadCultivationsForOrgUnit'), // needs to be loaded for displaying existing cultivations under each field selection card\r\n dispatch('reloadMixtures'),\r\n dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {root: true})\r\n ])\r\n\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n let loadExistingCultivation = null\r\n\r\n // TODO figure out what this is\r\n cultivationId\r\n ? loadExistingCultivation = Promise.all([\r\n axios.get(`/api/v2/cultivations/${cultivationId}`)\r\n .then(response => response.data),\r\n axios.get(`/api/v2/entities/orgunits/${orgUnitId}/cultivations/fields/${harvestYear}`)\r\n .then(response => response.data)\r\n ])\r\n .then(([cultivation, fieldsForCultivation]) => {\r\n cultivation.fieldIds = fieldsForCultivation[cultivation.id] || []\r\n commit('updateCultivation', cultivation)\r\n commit('editBuffer/reset', cultivation)\r\n })\r\n : commit('editBuffer/reset')\r\n\r\n // TODO remove later\r\n const initializeNewCultivation = () => {\r\n const additionalDefaults = {\r\n fieldIds: [fieldId],\r\n geometry: [rootState.fieldRecordSystem.data.field[fieldId].wkt]\r\n }\r\n\r\n commit('editBuffer/reset', additionalDefaults)\r\n }\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n\r\n return loadPrerequisiteData\r\n .then(cultivationId ? loadExistingCultivation : initializeNewCultivation)\r\n .then(commit('resetPredictedCrops'))\r\n .then(() => {\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n .catch(error => {\r\n console.error('error while starting cultivation planning')\r\n console.error(error)\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\nexport function reloadCultivationsForField ({commit, rootState}) {\r\n const fieldId = rootState.fieldRecordSystem.navigation.location.fieldId // TODO change update guard to orgunit\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n\r\n return axios.get(`/api/v2/entities/fields/${fieldId}/cultivations/${harvestYear}`)\r\n .then(response => response.data)\r\n .then(cultivations => {\r\n if (fieldId === rootState.fieldRecordSystem.navigation.location.fieldId) {\r\n commit('setCultivationsForField', cultivations.map(x => x.id)) // TODO instead replace cultivations on orgunit\r\n }\r\n })\r\n}\r\n\r\nexport const editCultivation = ({rootState, commit, dispatch}, cultivationId) => {\r\n // action is called when adding a cultivation on field level\r\n\r\n const loadPrerequisiteData = Promise.all([\r\n dispatch('reloadMixtures'),\r\n dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {root: true})\r\n ])\r\n\r\n let loadExistingCultivation = null\r\n\r\n cultivationId\r\n ? loadExistingCultivation = () => axios.get(`/api/v2/cultivations/${cultivationId}`)\r\n .then(response => response.data)\r\n .then(cultivation => {\r\n // commit('updateCultivation', cultivation)\r\n commit('editBuffer/reset', cultivation)\r\n })\r\n : commit('editBuffer/reset')\r\n\r\n const initializeNewCultivation = () => {\r\n const selectedFieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n\r\n if (!selectedFieldId) {\r\n throw new Error('[cultivation/resetEditBuffer] cannot create cultivation without selected field')\r\n }\r\n const additionalDefaults = {\r\n geometry: [rootState.fieldRecordSystem.data.field[selectedFieldId].wkt]\r\n }\r\n\r\n commit('editBuffer/reset', additionalDefaults)\r\n return dispatch('predictNextCrop')\r\n }\r\n\r\n const editCultivationPlanning = () => {\r\n if (rootState.fieldRecordSystem.navigation.location.fieldId) {\r\n commit('fieldRecordSystem/setRightView', 'cultivationPlanning', {root: true})\r\n } else {\r\n commit('fieldRecordSystem/setRightView', 'cultivationPlanningFromOrgUnit', {root: true})\r\n }\r\n }\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n\r\n return loadPrerequisiteData\r\n .then(cultivationId ? loadExistingCultivation : initializeNewCultivation)\r\n .then(commit('resetPredictedCrops'))\r\n .then(editCultivationPlanning)\r\n .then(() => {\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n .catch(error => {\r\n console.error('error while starting cultivation planning')\r\n console.error(error)\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\nexport const predictNextCrop = ({commit, rootState}) => {\r\n const fieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n\r\n return axios.get(`/api/v2/entities/fields/${fieldId}/data/crop-usage/next/${harvestYear}`)\r\n .then(response => response.data)\r\n .then(({cropUsageId}) => {\r\n commit('editBuffer/set', {cropUsageId})\r\n })\r\n}\r\n\r\nexport const reloadMixtures = ({commit, rootState}) => {\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return smarterGet([\r\n '/api/v2/entities/orgunits/{orgUnitId}/crop-mixtures/withproductnames'\r\n ], {\r\n id: 'reload.cropMixtures',\r\n expiry: 120,\r\n inputs: {\r\n orgUnitId: () => orgUnitId\r\n },\r\n sharedCache: true,\r\n onResult ([catchCropMixtures]) {\r\n commit('setMixtures', catchCropMixtures)\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n","export const currentSelectedFieldId = (state, getters, rootState) => rootState.fieldRecordSystem.navigation.location.fieldId\r\n\r\nexport const cultivationsForSelectedField = (state) => {\r\n // state.data.selection.field contains all cultivation ids the selected field currently has\r\n // state.data.selection.orgUnit contains all cultivations the current orgUnit has\r\n return state.data.selection.field.map(id => state.data.selection.orgUnit[id])\r\n}\r\n\r\n/*\r\n{\r\n fieldId1: [cultivation1, cultivation2...],\r\n fieldId2: [cultivation3, cultivation4...],\r\n fieldId3: [cultivation1, cultivation5...]\r\n}\r\n*/\r\nexport const cultivationsByFieldId = (state) => {\r\n const lookup = {}\r\n\r\n Object.keys(state.data.selection.orgUnit).forEach((cultivationId) => {\r\n const cultivation = state.data.selection.orgUnit[cultivationId]\r\n if (cultivation.fieldIds) { // workaround for timing issue when editing cultivations\r\n cultivation.fieldIds.forEach((fieldId) => {\r\n if (!lookup[fieldId]) {\r\n lookup[fieldId] = []\r\n }\r\n lookup[fieldId].push(cultivation)\r\n })\r\n }\r\n })\r\n return lookup\r\n}\r\n\r\n/*\r\n{\r\n main: [...fieldIds],\r\n secondary: [...fieldIds],\r\n catch: [...fieldIds],\r\n eco: [...fieldIds]\r\n}\r\n*/\r\nexport const fieldIdsByCultivationType = (state) => {\r\n const lookup = {}\r\n\r\n const cultivations = state.data.selection.orgUnit\r\n Object.keys(cultivations).forEach((cultivationId) => {\r\n const cultivation = cultivations[cultivationId]\r\n if (!lookup[cultivation.type]) {\r\n lookup[cultivation.type] = []\r\n }\r\n\r\n if (cultivation.fieldIds) { // workaround for iming issue when editing cultivations\r\n cultivation.fieldIds.forEach((id) => {\r\n if (!lookup[cultivation.type].includes(id)) {\r\n lookup[cultivation.type].push(id)\r\n }\r\n })\r\n }\r\n })\r\n return lookup\r\n}\r\n\r\nexport const fieldIdsByCropId = (state) => {\r\n const lookup = {}\r\n const cultivations = state.data.selection.orgUnit\r\n Object.keys(cultivations).forEach((cultivationId) => {\r\n const cultivation = cultivations[cultivationId]\r\n\r\n if (!cultivation.cropUsageId) return\r\n\r\n if (!lookup[cultivation.cropUsageId]) {\r\n lookup[cultivation.cropUsageId] = []\r\n }\r\n\r\n if (cultivation.fieldIds) { // workaround for timing issue when editing cultivations\r\n cultivation.fieldIds.forEach((fieldId) => {\r\n if (!lookup[cultivation.cropUsageId].includes(fieldId)) {\r\n lookup[cultivation.cropUsageId].push(fieldId)\r\n }\r\n })\r\n }\r\n })\r\n\r\n return lookup\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: '',\r\n type: 'main',\r\n dateTimeRange: {\r\n start: null,\r\n end: null\r\n },\r\n subsidies: {\r\n ecoPriorityArea: false,\r\n other: false\r\n },\r\n fieldIds: [],\r\n entityId: null,\r\n harvestYears: [],\r\n geometry: [],\r\n cropUsageId: null,\r\n // main\r\n expectedYield: 0,\r\n expectedYieldUnit: 'dt/ha',\r\n actualYield: null,\r\n // catch, eco+catch\r\n mixtureComponents: null,\r\n // eco\r\n ecoTypeId: null\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n getters: {\r\n isEcoPriorityArea (state) {\r\n return state.type === 'eco' || (state.type === 'catch' && state.subsidies.ecoPriorityArea)\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'subsidies',\r\n 'fieldIds',\r\n 'dateTimeRange',\r\n 'harvestYears',\r\n 'ecoTypeId',\r\n 'mixtureComponents',\r\n 'cropUsageId',\r\n 'type',\r\n 'actualYield',\r\n 'expectedYield',\r\n 'expectedYieldUnit',\r\n 'geometry'\r\n ]),\r\n set (state, partialCultivation) {\r\n if ('type' in partialCultivation && state.type !== partialCultivation.type) {\r\n const {subsidies, cropUsageId, mixtureComponents} = defaults()\r\n Object.assign(partialCultivation, {subsidies, cropUsageId, mixtureComponents})\r\n }\r\n\r\n Object.assign(state, partialCultivation)\r\n },\r\n reset (state, partialCultivation) {\r\n Object.assign(state, defaults(), partialCultivation)\r\n if (partialCultivation && typeof partialCultivation.geometry === 'string') {\r\n state.geometry = [partialCultivation.geometry]\r\n }\r\n }\r\n }\r\n}\r\n","import mutations from './mutations'\r\nimport * as actions from './actions'\r\nimport * as getters from './getters'\r\nimport editBuffer from './edit-buffer'\r\n\r\nconst state = {\r\n data: {\r\n selection: {\r\n field: [], // ids only\r\n orgUnit: {} // full objects keyed by id\r\n },\r\n ecoTypes: [],\r\n cultivationTypes: [],\r\n predictedCrops: {},\r\n mixtures: []\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n mutations,\r\n actions,\r\n getters,\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import Vue from 'vue'\r\n\r\nimport {cloneDeep} from 'lodash'\r\nimport {parse} from 'wellknown'\r\n\r\nimport {simplifyLowQuality} from '@helpers/geojson/simplification'\r\n\r\nconst mutations = {\r\n // TODO refactor, see ASK-2138\r\n setActionsForField(state, actions) {\r\n state.data.actions.forField = actions\r\n },\r\n // TODO refactor, see ASK-2138\r\n setActionsByField(state, {fieldId, actions}) {\r\n Vue.set(state.data.editing.actionsByField, fieldId, actions)\r\n },\r\n // TODO refactor, see ASK-2138\r\n setActionsForOrgUnit(state, actions) {\r\n state.data.actions.forOrgUnit = actions\r\n },\r\n addActionsForOrgUnit(state, actions) {\r\n state.data.actions.forOrgUnit.push(...actions)\r\n },\r\n setActionTemplates(state, actions) {\r\n state.data.actions.templatesForOrgUnit = actions\r\n },\r\n setWizardStep(state, step) {\r\n state.ui.planningWizard.step = step\r\n if (step === 'combinationStart') {\r\n state.ui.planningWizard.partEditingIndex = null\r\n state.editBuffer.productQuantities = []\r\n state.editBuffer.details = {}\r\n }\r\n },\r\n setParameterStep(state, step) {\r\n state.ui.planningWizard.parameterStep = step\r\n },\r\n replaceCombination(state, index) {\r\n const {type, procedure} = state.editBuffer\r\n // const {parameters, productQuantities} = state.editBuffer.details[state.editBuffer.fieldIds.find(x => x !== null)]\r\n const details = {}\r\n state.editBuffer.fieldIds.forEach(fieldId => {\r\n details[fieldId] = JSON.parse(\r\n JSON.stringify(state.editBuffer.details[fieldId])\r\n )\r\n })\r\n\r\n const {id} = state.data.planningWizard.combinationParts[index]\r\n\r\n state.data.planningWizard.combinationParts.splice(index, 1, {\r\n id,\r\n type,\r\n procedure,\r\n details,\r\n })\r\n },\r\n addCombinationPart(state) {\r\n const {type, procedure} = state.editBuffer\r\n\r\n const details = {}\r\n state.editBuffer.fieldIds.forEach(fieldId => {\r\n details[fieldId] = JSON.parse(\r\n JSON.stringify(state.editBuffer.details[fieldId])\r\n )\r\n })\r\n\r\n state.data.planningWizard.combinationParts.push({type, procedure, details})\r\n },\r\n setCombinationParts(state, parts) {\r\n state.data.planningWizard.combinationParts = parts\r\n },\r\n // TODO change signature to use index instead of object\r\n removeCombinationPart(state, part) {\r\n state.data.planningWizard.combinationParts = state.data.planningWizard.combinationParts.filter(\r\n x => x !== part\r\n )\r\n },\r\n updateActualAreaForPart(state, {index, fieldId, actualArea}) {\r\n state.data.planningWizard.combinationParts[index].details[fieldId] = {\r\n ...state.data.planningWizard.combinationParts[index].details[fieldId],\r\n actualArea,\r\n }\r\n },\r\n setActiveActionId(state, actionId) {\r\n state.ui.selection.actionId = actionId\r\n },\r\n setPartEditingIndex(state, index) {\r\n state.ui.planningWizard.partEditingIndex = index\r\n },\r\n // setActionIndex (state, index) {\r\n // state.editBuffer.indexFromAction = index\r\n // },\r\n // setCombinationActionWasEdited (state) {\r\n // state.editBuffer.combinationActionWasEdited = !state.editBuffer.combinationActionWasEdited\r\n // },\r\n setActionStateForOrgUnit(state, {action, newState}) {\r\n const currentAction = state.data.actions.forOrgUnit.find(\r\n x => x.id === action.id\r\n )\r\n currentAction.timestamps.actual.start = newState.start\r\n currentAction.timestamps.actual.end = newState.end\r\n },\r\n setActionStateForField(state, {action, newState}) {\r\n const currentAction = state.data.actions.forField.find(\r\n x => x.id === action.id\r\n )\r\n currentAction.timestamps.actual.start = newState.start\r\n currentAction.timestamps.actual.end = newState.end\r\n },\r\n setCultivationsForOrgUnit(state, cultivations) {\r\n state.cultivationsForOrgUnit = {}\r\n cultivations.forEach(cultivation => {\r\n const geometry = parse(cultivation.geometry)\r\n\r\n cultivation.geojsonGeometry = geometry\r\n\r\n const simplifiedGeometry = cloneDeep(geometry)\r\n // TODO find out why we have cultivations with empty geometries\r\n if (simplifiedGeometry && simplifiedGeometry.coordinates.length) {\r\n simplifyLowQuality(simplifiedGeometry)\r\n }\r\n\r\n cultivation.simplifiedGeometry = simplifiedGeometry\r\n\r\n Vue.set(state.cultivationsForOrgUnit, cultivation.id, cultivation)\r\n })\r\n },\r\n setNavigationSource(state, {cancelTarget, saveTarget}) {\r\n state.navigationSource = {cancelTarget, saveTarget}\r\n },\r\n reset (state) {\r\n state.data.planningWizard.combinationParts = []\r\n },\r\n}\r\n\r\nexport default mutations\r\n","export default {\r\n combination: ['start', 'combinationStart', 'type', 'parameters', 'misc', 'status', 'combinationSummary']\r\n}\r\n","import wizardSteps from './wizard-steps'\r\nimport {procedureParameterSteps} from './action-hierarchy'\r\n\r\nconst nextFromArray = (array, current) => array[array.indexOf(current) + 1]\r\nconst previousFromArray = (array, current) => array[array.indexOf(current) - 1]\r\n\r\nexport function next ({state, commit, dispatch}) {\r\n const {type, procedure} = state.editBuffer\r\n\r\n const {step: current} = state.ui.planningWizard\r\n\r\n if (current === 'start') {\r\n commit('fieldRecordSystem/setWorkflow', {'fieldSelection': false}, {root: true})\r\n }\r\n\r\n const parameterSteps = procedureParameterSteps(type, procedure)\r\n\r\n if (current === 'parameters') {\r\n const nextParameterStep = nextFromArray(parameterSteps, state.ui.planningWizard.parameterStep)\r\n\r\n if (nextParameterStep) {\r\n commit('setParameterStep', nextParameterStep)\r\n return\r\n } else {\r\n const {partEditingIndex} = state.ui.planningWizard\r\n\r\n if (partEditingIndex === null) {\r\n commit('addCombinationPart')\r\n } else {\r\n commit('replaceCombination', partEditingIndex)\r\n // commit('setCombinationActionWasEdited')\r\n // commit('setActionIndex', null)\r\n }\r\n\r\n commit('editBuffer/partialReset')\r\n\r\n // loop back to inner loop start for combination action\r\n commit('setWizardStep', 'combinationStart')\r\n\r\n return\r\n }\r\n // fall through to next wizard step\r\n }\r\n\r\n const nextStep = nextFromArray(wizardSteps.combination, current)\r\n\r\n if (nextStep) {\r\n // display action type selection without summary page when entering wizard first time\r\n if (nextStep === 'combinationStart' && !state.data.planningWizard.combinationParts.length) {\r\n commit('setWizardStep', 'type')\r\n return\r\n }\r\n commit('setWizardStep', nextStep)\r\n\r\n if (nextStep === 'type') {\r\n commit('setWizardStep', 'misc')\r\n }\r\n\r\n if (nextStep === 'parameters') {\r\n if (parameterSteps.length) {\r\n // instantiate default parameter object in editBuffer\r\n commit('setParameterStep', parameterSteps[0])\r\n\r\n commit('editBuffer/resetDetails')\r\n } else {\r\n // skip parameter step if this procedure has no parameter form\r\n return dispatch('next')\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function back ({state, commit, dispatch}) {\r\n const {type, procedure} = state.editBuffer\r\n\r\n const {step: current} = state.ui.planningWizard\r\n\r\n const parameterSteps = procedureParameterSteps(type, procedure)\r\n\r\n if (current === 'type' || current === 'combinationStart') {\r\n commit('fieldRecordSystem/setWorkflow', {'fieldSelection': true}, {root: true})\r\n }\r\n\r\n if (current === 'parameters') {\r\n const previousParameterStep = previousFromArray(parameterSteps, state.ui.planningWizard.parameterStep)\r\n\r\n if (previousParameterStep) {\r\n commit('setParameterStep', previousParameterStep)\r\n\r\n return\r\n }\r\n // fall through to previous wizard step\r\n }\r\n\r\n const validSteps = wizardSteps.combination.filter(x => x !== 'status')\r\n\r\n const previousStep = previousFromArray(validSteps, current)\r\n\r\n if (previousStep) {\r\n commit('setWizardStep', previousStep)\r\n\r\n if (previousStep === 'parameters') {\r\n commit('setWizardStep', 'combinationStart')\r\n }\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\nimport {can} from 'src/js/helpers/permissions'\r\n\r\nexport * from './wizard-actions'\r\n\r\nexport const reloadActionData = ({commit, dispatch}) => {\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n\r\n return Promise.all([\r\n dispatch('fieldRecordSystem/machines/loadMachines', null, {root: true}),\r\n dispatch('fieldRecordSystem/persons/loadPersons', null, {root: true}),\r\n dispatch('loadCultivationsForOrgUnit', null),\r\n dispatch('masterData/reloadCropUsages', null, {root: true}),\r\n dispatch('masterData/reloadCropHarvestQualities', null, {root: true}),\r\n dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {\r\n root: true,\r\n }),\r\n ]).then(() => {\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\n// TODO refactor, see ASK-2138\r\nexport const loadActionsForOrgUnit = ({rootGetters, commit, rootState}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n if (can(rootState.permissions, 'Use.Frs.Actions')) {\r\n return smarterGet(['/api/v2/{harvestYear}/org/{orgUnitId}/actions'], {\r\n id: 'data.orgUnit.actions',\r\n expiry: 0,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n harvestYear: () => harvestYear,\r\n },\r\n sharedCache: true,\r\n onResult([data]) {\r\n commit('setActionsForOrgUnit', data)\r\n },\r\n })\r\n } else {\r\n Promise.resolve()\r\n }\r\n}\r\n\r\n// TODO refactor, see ASK-2138\r\nexport function loadActionsForCurrentField({rootGetters, commit}) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n return smarterGet(['/api/v2/{harvestYear}/fields/{fieldId}/actions'], {\r\n id: 'data.field.actions',\r\n expiry: 0, // when creating actions make sure the action is displayed immediately // TODO refactor saving of actions to update client-side on its own, making caching here possible\r\n inputs: {\r\n fieldId: () => fieldId,\r\n harvestYear: () => harvestYear,\r\n },\r\n sharedCache: true,\r\n onResult([data]) {\r\n // NOTE not to be confused with setActionsByField used below in loadActionsForCurrentField\r\n commit('setActionsForField', data)\r\n },\r\n })\r\n}\r\n\r\n// TODO refactor, see ASK-2138\r\nexport function loadActionsForFieldForPlanning({commit, rootState}, fieldId) {\r\n return smarterGet(['/api/v2/{harvestYear}/fields/{fieldId}/actions'], {\r\n id: 'data.field.actions',\r\n expiry: 10,\r\n inputs: {\r\n fieldId: () => fieldId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear,\r\n },\r\n onResult([actions]) {\r\n // NOTE not to be confused with setActionsForField used above in loadActionsForField\r\n commit('setActionsByField', {fieldId, actions})\r\n },\r\n })\r\n}\r\n\r\nexport const startEditingCombinationPart = ({commit}, {part, index}) => {\r\n // const clone = JSON.parse(JSON.stringify(part))\r\n // const modifiedAction = {\r\n // ...clone,\r\n // timestamps: state.editBuffer.timestamps,\r\n // fieldIds: state.editBuffer.fieldIds,\r\n // combinationActionWasEdited: true,\r\n // indexFromAction: index\r\n // }\r\n const {id, ...rest} = part\r\n\r\n commit('editBuffer/set', rest)\r\n commit('setPartEditingIndex', index)\r\n commit('setWizardStep', 'type')\r\n // return dispatch('reloadActionData')\r\n // .then(() => {\r\n // commit('editBuffer/reset', modifiedAction)\r\n // commit('setWizardStep', 'type')\r\n // })\r\n}\r\n\r\nexport async function startCreatingActionFromField({dispatch}) {\r\n dispatch('startEditingAction', {\r\n navigationSource: {\r\n saveTarget: 'actionDisplayField',\r\n cancelTarget: 'default',\r\n },\r\n })\r\n}\r\n\r\nexport function startEditingActionGeometry({state, getters, dispatch}) {\r\n const fieldId = state.editBuffer.fieldIds[0]\r\n const feature = getters['editBuffer/finalActionFeatures'][fieldId]\r\n\r\n const features = feature ? [feature] : []\r\n\r\n return dispatch('fieldRecordSystem/map/startExpertMode', features, {\r\n root: true,\r\n })\r\n}\r\n\r\nexport const cancelEditing = ({state, commit}) => {\r\n commit('editBuffer/reset')\r\n commit('setWizardStep', null)\r\n\r\n const {cancelTarget} = state.navigationSource\r\n commit('fieldRecordSystem/setRightView', cancelTarget, {root: true})\r\n}\r\n\r\nexport const showActionDetails = ({commit}, actionId) => {\r\n commit('setActiveActionId', actionId)\r\n commit('fieldRecordSystem/setRightView', 'actionDetailsPage', {root: true})\r\n}\r\n\r\nexport const saveModifiedActionStatus = (\r\n {state, commit, rootGetters},\r\n {actions, newState, forOrgUnit}\r\n) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n if (forOrgUnit) {\r\n actions.forEach(action => {\r\n commit('setActionStateForOrgUnit', {action, newState})\r\n })\r\n } else {\r\n actions.forEach(action => {\r\n commit('setActionStateForField', {action, newState})\r\n })\r\n }\r\n\r\n const stateActions = forOrgUnit ? state.data.actions.forOrgUnit : state.data.actions.forField\r\n const actionsToUpdate = stateActions.filter(existing => actions.some(x => x.id === existing.id))\r\n return axios.post(`/api/v2/${harvestYear}/orgs/${orgUnitId}/actions`, actionsToUpdate)\r\n}\r\n\r\nexport const removeActions = ({commit, dispatch}, actions) => {\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n const actionIds = actions.map(x => x.id)\r\n return axios\r\n .post('/api/v2/actions/delete', actionIds)\r\n .then(() => {\r\n dispatch('loadActionsForOrgUnit')\r\n })\r\n .then(() => {\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\nexport const loadCultivationsForOrgUnit = ({rootState, commit}) => {\r\n if (can(rootState.permissions, 'Use.Frs.Cultivations')) {\r\n return smarterGet(\r\n [\r\n '/api/v2/entities/orgunits/{orgUnitId}/cultivations/{harvestYear}',\r\n '/api/v2/entities/orgunits/{orgUnitId}/cultivations/fields/{harvestYear}',\r\n ],\r\n {\r\n id: 'orgUnit.action.cultivations',\r\n expiry: 10,\r\n inputs: {\r\n orgUnitId: () =>\r\n rootState.fieldRecordSystem.navigation.location.orgUnitId,\r\n harvestYear: () =>\r\n rootState.fieldRecordSystem.userSettings.harvestYear,\r\n },\r\n sharedCache: true,\r\n onResult([cultivations, fieldsUnderCultivations]) {\r\n cultivations.forEach(cultivation => {\r\n cultivation.fieldIds = fieldsUnderCultivations[cultivation.id]\r\n ? fieldsUnderCultivations[cultivation.id]\r\n : []\r\n })\r\n commit('setCultivationsForOrgUnit', cultivations)\r\n },\r\n }\r\n )\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {cloneDeep} from 'lodash'\r\n\r\n/**\r\n * Adapter function to convert current editBuffer structure to more useful format\r\n * @param {string[]} fieldIds\r\n * @param {object[]} combinationParts\r\n * @returns\r\n */\r\nfunction groupByField(fieldIds, combinationParts) {\r\n return fieldIds.reduce((lookup, fieldId) => {\r\n lookup[fieldId] = combinationParts.map(\r\n ({\r\n id, // does not exist in editBuffer right now, but will need to exist for editing\r\n type,\r\n procedure,\r\n details: {\r\n [fieldId]: {\r\n actualArea, // does not exist in editBuffer right now, but will need to exist for saving/editing\r\n parameters,\r\n productQuantities,\r\n },\r\n },\r\n }) => ({\r\n id,\r\n type,\r\n procedure,\r\n parameters,\r\n productQuantities,\r\n actualArea,\r\n })\r\n )\r\n\r\n return lookup\r\n }, {})\r\n}\r\n\r\nexport default async function({\r\n state,\r\n getters,\r\n rootState,\r\n rootGetters,\r\n commit,\r\n}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const {\r\n id,\r\n timestamps,\r\n personnel,\r\n machines,\r\n notes,\r\n fieldIds,\r\n } = state.editBuffer\r\n\r\n const sharedProperties = {\r\n id,\r\n timestamps,\r\n personnel,\r\n machines,\r\n notes,\r\n }\r\n\r\n if (id && fieldIds.length > 1) {\r\n throw new Error(\r\n 'Editing is currently only supported for a single action/field'\r\n )\r\n }\r\n\r\n const actionPartsByFieldId = groupByField(\r\n fieldIds,\r\n state.data.planningWizard.combinationParts\r\n )\r\n\r\n const makeActionWithParts = fieldId =>\r\n cloneDeep({\r\n ...sharedProperties,\r\n fieldId,\r\n geometry: getters['editBuffer/finalActionFeatures'][fieldId].geometry,\r\n planningParts: actionPartsByFieldId[fieldId],\r\n })\r\n\r\n const actions = fieldIds.map(makeActionWithParts, [])\r\n\r\n await axios.post(`/api/v2/${harvestYear}/orgs/${orgUnitId}/actions`, actions)\r\n\r\n // TODO figure out why field actions are brute-force reloaded, but org actions were not\r\n // TODO find out what needs reloading and what doesn't\r\n // await dispatch('loadActionsForOrgUnit')\r\n // await dispatch('loadActionsForCurrentField')\r\n\r\n const {saveTarget} = state.navigationSource\r\n commit('fieldRecordSystem/setRightView', saveTarget, {root: true})\r\n}\r\n","import axios from 'axios'\r\nimport {cloneDeep} from 'lodash'\r\n\r\nfunction transformPlanningPartsToCombinationParts(fieldId, planningParts) {\r\n return cloneDeep(\r\n planningParts.map(\r\n ({id, type, procedure, parameters, productQuantities, actualArea}) => ({\r\n id,\r\n type,\r\n procedure,\r\n details: {\r\n [fieldId]: {\r\n actualArea,\r\n parameters,\r\n productQuantities,\r\n },\r\n },\r\n })\r\n )\r\n )\r\n}\r\n\r\nexport default async function startEditingAction(\r\n {state, commit, dispatch, rootState},\r\n {actionId, navigationSource: {cancelTarget, saveTarget}}\r\n) {\r\n commit('setNavigationSource', {cancelTarget, saveTarget})\r\n\r\n await dispatch('reloadActionData')\r\n\r\n commit('editBuffer/reset')\r\n commit('reset')\r\n commit('setWizardStep', 'start')\r\n\r\n const {location} = rootState.fieldRecordSystem.navigation\r\n\r\n if (actionId) {\r\n const {data: action} = await axios.get(`/api/v2/actions/${actionId}`)\r\n\r\n const {\r\n fieldId,\r\n geometry,\r\n planningParts,\r\n orgUnitId, // not used for editing\r\n auditInfo, // not used for editing\r\n mainCultivation, // not used for editing\r\n usesExperimentalFinanceIntegration, // not used for editing\r\n area, // not used for editing\r\n ...restOfAction\r\n } = action\r\n\r\n if (usesExperimentalFinanceIntegration) {\r\n throw new Error('cannot edit actions using lots right now')\r\n }\r\n\r\n // TODO find out why fieldId is even necessary\r\n await dispatch('editBuffer/toggleFieldId', fieldId)\r\n\r\n commit('editBuffer/setCustomGeometry', {fieldId, geometry})\r\n commit('editBuffer/set', {...restOfAction})\r\n\r\n const combinationParts = transformPlanningPartsToCombinationParts(\r\n fieldId,\r\n planningParts\r\n )\r\n commit('setCombinationParts', combinationParts)\r\n commit('setWizardStep', 'combinationStart')\r\n } else if (location.fieldId) {\r\n await dispatch('editBuffer/toggleFieldId', location.fieldId)\r\n }\r\n\r\n const editingViewMapping = {\r\n actionDetailsPage: 'actionPlanningForSingleFieldFromList',\r\n actionOverview: 'actionPlanningFromOverview',\r\n }\r\n\r\n const editingView =\r\n editingViewMapping[rootState.fieldRecordSystem.ui.view.right] ||\r\n (location.fieldId\r\n ? 'actionPlanningForSingleField'\r\n : 'actionPlanningFromDashboard')\r\n\r\n commit('fieldRecordSystem/setRightView', editingView, {root: true})\r\n}\r\n","import wizardSteps from './wizard-steps'\r\n\r\nexport const finished = state => {\r\n const {step} = state.ui.planningWizard\r\n\r\n const validSteps = wizardSteps.combination.filter(x => x !== 'status')\r\n\r\n if (validSteps.indexOf(step) === validSteps.length - 1) {\r\n return true\r\n } else {\r\n return false\r\n }\r\n}\r\n\r\nexport const cultivationsByFieldId = state => {\r\n const lookup = {}\r\n\r\n Object.keys(state.cultivationsForOrgUnit).forEach(cultivationId => {\r\n const cultivation = state.cultivationsForOrgUnit[cultivationId]\r\n if (cultivation.fieldIds) { // workaround for timing issue when editing cultivations\r\n cultivation.fieldIds.forEach((fieldId) => {\r\n if (!lookup[fieldId]) {\r\n lookup[fieldId] = []\r\n }\r\n lookup[fieldId].push(cultivation)\r\n })\r\n }\r\n })\r\n return lookup\r\n}\r\n\r\nexport const activeAction = state => {\r\n return state.ui.selection.actionId ? state.data.actions.forField.find(x => x.id === state.ui.selection.actionId) : null\r\n}\r\n","import {mapValues, groupBy, flatten, pickBy} from 'lodash'\r\nimport {union, difference, intersect, buffer, helpers} from '@turf/turf'\r\nimport {computeSize} from '@helpers/openlayers/computation'\r\n\r\n// grouped by fieldId\r\nexport function fieldCultivationFeaturePairs (state, getters, rootState) {\r\n const fieldData = rootState.fieldRecordSystem.data.field\r\n\r\n return mapValues(getters.relevantCultivationsByFieldId, (cultivations, fieldId) => {\r\n if (!fieldData[fieldId].geometry) {\r\n return []\r\n }\r\n\r\n const fieldFeature = helpers.feature(fieldData[fieldId].geometry, {fieldId})\r\n\r\n return cultivations\r\n .map(cultivation => ({\r\n fieldFeature,\r\n cultivationFeature: helpers.feature(cultivation.geojsonGeometry, {\r\n cultivation\r\n })\r\n }))\r\n })\r\n}\r\n// grouped by fieldId\r\nexport function clippedCultivationFeatures (state, getters) {\r\n return mapValues(getters.fieldCultivationFeaturePairs, (featurePairs, fieldId) => {\r\n return featurePairs\r\n .reduce((features, {fieldFeature, cultivationFeature}) => {\r\n try {\r\n const feature = intersect(cultivationFeature, fieldFeature)\r\n if (feature) {\r\n feature.properties = {\r\n ...cultivationFeature.properties,\r\n fieldId\r\n }\r\n features.push(feature)\r\n }\r\n } catch {\r\n console.error({cultivationFeature, fieldFeature})\r\n }\r\n\r\n return features\r\n }, [])\r\n })\r\n}\r\n// grouped by cultivationId\r\nexport function cutOffCultivationFeatures (state, getters, rootState) {\r\n const flatFeaturePairs = flatten(Object.values(getters.fieldCultivationFeaturePairs))\r\n\r\n const groupedPairs = groupBy(flatFeaturePairs, pair => pair.cultivationFeature.properties.cultivation.id)\r\n\r\n const lookup = mapValues(groupedPairs, (features, cultivationId) => {\r\n const cultivationFeature = groupedPairs[cultivationId][0].cultivationFeature\r\n const fieldFeatures = groupedPairs[cultivationId].map(pair => pair.fieldFeature)\r\n\r\n return fieldFeatures.reduce((feature, fieldFeature) => feature ? difference(feature, fieldFeature) : null, cultivationFeature)\r\n })\r\n\r\n return pickBy(lookup, feature => feature)\r\n}\r\n// grouped by fieldId\r\nexport function combinedCultivationFeatures (state, getters, rootState, rootGetters) {\r\n return mapValues(getters.clippedCultivationFeatures, features => {\r\n if (!features.length) return null\r\n if (features.length === 1) return features[0]\r\n\r\n return features.reduce((merged, feature) => union(merged, feature))\r\n })\r\n}\r\n// grouped by fieldId\r\nexport function remainingFieldFeatures (state, getters, rootState) {\r\n const fieldData = rootState.fieldRecordSystem.data.field\r\n return mapValues(getters.combinedCultivationFeatures, (combinedCultivationGeometry, fieldId) => {\r\n const fieldGeometry = fieldData[fieldId].geometry\r\n\r\n if (!fieldGeometry) return null\r\n\r\n if (!combinedCultivationGeometry) return helpers.feature(fieldGeometry)\r\n\r\n const feature = difference(helpers.feature(fieldGeometry), combinedCultivationGeometry)\r\n\r\n if (!feature) return null\r\n\r\n const bufferedFeature = buffer(feature, -0.00005) // NOTE hacky fix around degeneracies with shared edges\r\n return bufferedFeature === undefined ? null : bufferedFeature\r\n })\r\n}\r\n// grouped by fieldId\r\nexport function finalActionFeatures (state, getters, rootState, rootGetters) {\r\n const fieldData = rootState.fieldRecordSystem.data.field\r\n\r\n return mapValues(state.customGeometries, (customGeometry, fieldId) => {\r\n if (customGeometry) return helpers.feature(customGeometry)\r\n\r\n const availableCultivations = getters.relevantCultivationsByFieldId[fieldId]\r\n const selectedCultivations = getters.selectedCultivationIdsByFieldId[fieldId]\r\n\r\n const allCultivationsSelected = availableCultivations.length === selectedCultivations.length\r\n const remainingFieldSelected = state.remainingFieldSelected[fieldId]\r\n\r\n // just use field geometry if everything is selected, to save effort and prevent artifacts when merging all geometries again\r\n if (allCultivationsSelected && remainingFieldSelected) {\r\n return helpers.feature(fieldData[fieldId].geometry)\r\n }\r\n\r\n const features = []\r\n\r\n const cultivationFeatures = getters.clippedCultivationFeatures[fieldId].filter(x => {\r\n return state.selectedCultivationIds[x.properties.cultivation.id] === fieldId\r\n })\r\n features.push(...cultivationFeatures)\r\n\r\n if (remainingFieldSelected) {\r\n features.push(getters.remainingFieldFeatures[fieldId])\r\n }\r\n\r\n if (!features.length) return null\r\n if (features.length === 1) return features[0]\r\n\r\n const filteredFeatures = features.filter(feature => feature)\r\n\r\n return filteredFeatures.reduce((merged, feature) => union(merged, feature))\r\n })\r\n}\r\n\r\nexport function finalActionTotalArea (state, getters) {\r\n if (!Object.values(getters.finalActionFeatures).every(x => x)) return 0\r\n const areaFeatures = Object.values(getters.finalActionFeatures)\r\n\r\n return areaFeatures.reduce((sum, next) => sum + computeSize(next.geometry), 0)\r\n}\r\n","import {mapValues} from 'lodash'\r\n\r\nexport function selectionSummaryByFieldId (state, getters) {\r\n return mapValues(getters.relevantCultivationsByFieldId, (cultivations, fieldId) => {\r\n const selectedCultivationCount = cultivations.filter(cultivation => state.selectedCultivationIds[cultivation.id] === fieldId).length\r\n const availableCultivationCount = cultivations.length\r\n\r\n const atLeastOneCultivationSelected = selectedCultivationCount > 0\r\n const allCultivationsSelected = selectedCultivationCount === availableCultivationCount\r\n const hasRemainingField = !!getters.remainingFieldFeatures[fieldId]\r\n const remainingFieldSelected = hasRemainingField && !!state.remainingFieldSelected[fieldId]\r\n const hasCustomGeometry = !!state.customGeometries[fieldId]\r\n\r\n const somethingSelected = atLeastOneCultivationSelected || remainingFieldSelected || hasCustomGeometry\r\n const everythingSelected = allCultivationsSelected && (remainingFieldSelected || !hasRemainingField)\r\n\r\n return {\r\n selectedCultivationCount,\r\n availableCultivationCount,\r\n hasRemainingField,\r\n remainingFieldSelected,\r\n somethingSelected,\r\n everythingSelected,\r\n hasCustomGeometry\r\n }\r\n })\r\n}\r\n","import Vue from 'vue'\r\nimport moment from 'moment'\r\nimport {mapValues, forIn, flatten, fromPairs} from 'lodash'\r\n\r\nimport {procedureParameterDefaults, procedures} from '../action-hierarchy'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as geometryGetters from './geometry-getters'\r\nimport * as selectionGetters from './selection-getters'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n timestamps: {\r\n withTime: false, // wether the planned timestamps is used with or without time needs to be stored in the state\r\n // since the summary wizard page needs to display the timestamps accordingly\r\n planned: {\r\n start: null,\r\n end: null\r\n },\r\n actual: {\r\n start: null,\r\n end: null\r\n }\r\n },\r\n fieldIds: [], // single value for final action, but planning can happen for multiple fields at once\r\n\r\n // cultivation/geometry data\r\n selectedCultivationIds: {}, // {[cultivationId]: fieldId} // TODO rename later\r\n remainingFieldSelected: {}, // {[fieldId]: true|false}\r\n customGeometries: {}, // {[fieldId]: geoJsonGeometry}\r\n\r\n // combination sub wizard data\r\n type: null,\r\n procedure: null,\r\n details: {}, // {[fieldId]: {parameters, productQuantities}}\r\n parameters: {},\r\n // productQuantities: [], // Array with subschema `{productId: \"\", amount: 0, unit: \"\"}`\r\n\r\n personnel: [], // Array\r\n machines: [], // Array\r\n notes: '',\r\n // combinationActionWasEdited: false,\r\n // indexFromAction: null,\r\n // instanceId: null,\r\n harvestYear: 0\r\n})\r\n\r\nfunction resetDetails (state) {\r\n state.details = state.fieldIds.reduce((detailsLookup, fieldId) => {\r\n const defaults = procedureParameterDefaults(state.type, state.procedure)\r\n const currentParameters =\r\n state.details[fieldId]\r\n ? state.details[fieldId].parameters\r\n : state.parameters\r\n ? state.parameters\r\n : {}\r\n const productQuantities =\r\n state.details[fieldId]\r\n ? state.details[fieldId].productQuantities\r\n : state.productQuantities\r\n ? state.productQuantities\r\n : []\r\n\r\n const parameters = Object.assign({}, defaults, currentParameters)\r\n\r\n for (let key in parameters) {\r\n if (!defaults.hasOwnProperty(key)) {\r\n delete parameters[key]\r\n }\r\n }\r\n\r\n detailsLookup[fieldId] = {\r\n parameters,\r\n productQuantities\r\n }\r\n return detailsLookup\r\n }, {})\r\n}\r\n\r\nfunction setType (state, type) {\r\n state.type = type\r\n\r\n state.procedure = procedures(type)[0] || null\r\n resetDetails(state)\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n getters: {\r\n ...geometryGetters,\r\n ...selectionGetters,\r\n valid (state) {\r\n // return executeRules(state, rules)\r\n return true && state\r\n },\r\n hasStarted: state => !!state.timestamps.started && !state.timestamps.completed,\r\n isPlanned: state => !state.timestamps.started,\r\n isCompleted: state => !!state.timestamps.completed,\r\n relevantCultivationsByFieldId (state, getters, rootState, rootGetters) {\r\n const cultivationsByFieldId = rootGetters['fieldRecordSystem/action/cultivationsByFieldId']\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n\r\n // TODO filter by referencing cultivation.dateTimeRange with action.dateTimeRange\r\n const lookup = fieldId\r\n ? {\r\n [fieldId]: cultivationsByFieldId[fieldId]\r\n }\r\n : mapValues(cultivationsByFieldId, (cultivations, fieldId) => {\r\n return cultivations\r\n })\r\n\r\n if (fieldId) {\r\n if (!lookup[fieldId]) {\r\n lookup[fieldId] = []\r\n }\r\n } else {\r\n rootGetters['fieldRecordSystem/fieldsForCurrentOrgUnit']\r\n .forEach(field => {\r\n if (!lookup[field.id]) {\r\n lookup[field.id] = []\r\n }\r\n })\r\n }\r\n\r\n return lookup\r\n },\r\n selectedCultivationIdsByFieldId (state) {\r\n const lookup = {}\r\n\r\n state.fieldIds.forEach(fieldId => {\r\n lookup[fieldId] = []\r\n })\r\n\r\n forIn(state.selectedCultivationIds, (fieldId, cultivationId) => {\r\n lookup[fieldId].push(cultivationId)\r\n })\r\n\r\n return lookup\r\n },\r\n cultivationDateValidityLookup (state, getters, rootState, rootGetters) {\r\n const cultivations = flatten(Object.values(rootGetters['fieldRecordSystem/action/cultivationsByFieldId']))\r\n\r\n const {start, end} = state.timestamps.planned\r\n const [min, max] = [\r\n start ? moment(start).valueOf() : -Infinity,\r\n end ? moment(end).valueOf() : Infinity\r\n ]\r\n\r\n return fromPairs(cultivations.map(cultivation => {\r\n const {start: cultivationStart, end: cultivationEnd} = cultivation.dateTimeRange\r\n const [a, b] = [cultivationStart, cultivationEnd].map(x => moment(x).valueOf())\r\n\r\n return [\r\n cultivation.id,\r\n (a >= min || b >= min) && (a <= max || b <= max)\r\n ]\r\n }))\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'notes',\r\n 'details',\r\n 'timestamps.withTime'\r\n ]),\r\n setType,\r\n resetDetails,\r\n partialReset (state) {\r\n state.type = null\r\n state.procedure = null\r\n state.parameters = {}\r\n },\r\n toggleFieldId (state, {fieldId, relevantCultivationIds}) {\r\n if (!state.fieldIds.includes(fieldId)) {\r\n state.fieldIds.push(fieldId)\r\n Vue.set(state.remainingFieldSelected, fieldId, true)\r\n Vue.set(state.customGeometries, fieldId, null)\r\n relevantCultivationIds.forEach(cultivationId => {\r\n Vue.set(state.selectedCultivationIds, cultivationId, fieldId)\r\n })\r\n } else {\r\n state.fieldIds = state.fieldIds.filter(x => x !== fieldId)\r\n Object.keys(state.selectedCultivationIds)\r\n .filter(cultivationId => state.selectedCultivationIds[cultivationId] === fieldId)\r\n .forEach(cultivationId => {\r\n Vue.delete(state.selectedCultivationIds, cultivationId)\r\n })\r\n Vue.delete(state.remainingFieldSelected, fieldId)\r\n Vue.delete(state.customGeometries, fieldId)\r\n }\r\n },\r\n setCustomGeometry (state, {fieldId, geometry}) {\r\n if (!state.fieldIds.includes(fieldId)) throw new Error(`fieldId ${fieldId} is not selected, cannot set geometry`)\r\n\r\n state.customGeometries[fieldId] = geometry\r\n\r\n if (geometry) {\r\n Object.keys(state.selectedCultivationIds)\r\n .filter(cultivationId => state.selectedCultivationIds[cultivationId] === fieldId)\r\n .forEach(cultivationId => {\r\n Vue.delete(state.selectedCultivationIds, cultivationId)\r\n })\r\n state.remainingFieldSelected[fieldId] = false\r\n }\r\n },\r\n toggleCultivationId (state, {fieldId, cultivationId}) {\r\n if (!state.fieldIds.includes(fieldId)) throw new Error(`fieldId ${fieldId} is not selected, cannot toggle cultivation`)\r\n\r\n if (!cultivationId) {\r\n state.remainingFieldSelected[fieldId] = !state.remainingFieldSelected[fieldId]\r\n if (state.remainingFieldSelected[fieldId]) {\r\n state.customGeometries[fieldId] = null\r\n }\r\n } else {\r\n if (state.selectedCultivationIds[cultivationId] === fieldId) {\r\n Vue.delete(state.selectedCultivationIds, cultivationId)\r\n } else {\r\n Vue.set(state.selectedCultivationIds, cultivationId, fieldId)\r\n }\r\n if (state.selectedCultivationIds[cultivationId] === fieldId) {\r\n state.customGeometries[fieldId] = null\r\n }\r\n }\r\n },\r\n setPlannedStart (state, isoDate) {\r\n state.timestamps.planned.start = isoDate\r\n },\r\n setPlannedEnd (state, isoDate) {\r\n state.timestamps.planned.end = isoDate\r\n },\r\n setActualStart (state, isoDate) {\r\n state.timestamps.actual.start = isoDate\r\n },\r\n setActualEnd (state, isoDate) {\r\n state.timestamps.actual.end = isoDate\r\n },\r\n setProcedure (state, procedure) {\r\n state.procedure = procedure\r\n\r\n resetDetails(state)\r\n },\r\n setMachineIds (state, machines) {\r\n state.machines = machines\r\n },\r\n setPersonnelIds (state, personnel) {\r\n state.personnel = personnel\r\n },\r\n set (state, partialAction) {\r\n const defaultAction = defaults()\r\n for (const key in partialAction) {\r\n if (!(key in defaultAction)) {\r\n console.error(`[action editBuffer] set: property '${key}' does not exist in action defaults`)\r\n }\r\n }\r\n\r\n Object.assign(state, partialAction)\r\n\r\n if (partialAction.fieldIds) {\r\n resetDetails(state)\r\n }\r\n },\r\n reset (state, action) {\r\n if (action) {\r\n throw new Error('deprecated parameter `action` should not be used')\r\n }\r\n Object.assign(state, defaults())\r\n }\r\n },\r\n actions: {\r\n toggleCultivationId ({state, getters, rootGetters, commit, dispatch}, {fieldId, cultivationId}) {\r\n const isFieldLevel = rootGetters['fieldRecordSystem/fieldId']\r\n\r\n if (isFieldLevel) {\r\n commit('toggleCultivationId', {fieldId, cultivationId})\r\n return\r\n }\r\n\r\n if (!state.fieldIds.includes(fieldId)) {\r\n dispatch('toggleFieldId', fieldId)\r\n commit('toggleCultivationId', {fieldId, cultivationId: null})\r\n getters.relevantCultivationsByFieldId[fieldId]\r\n .map(x => x.id)\r\n .filter(x => x !== cultivationId)\r\n .forEach(cultivationId => {\r\n commit('toggleCultivationId', {fieldId, cultivationId})\r\n })\r\n } else {\r\n commit('toggleCultivationId', {fieldId, cultivationId})\r\n }\r\n\r\n const atLeastOneCultivationSelected = getters.relevantCultivationsByFieldId[fieldId].some(cultivation => state.selectedCultivationIds[cultivation.id] === fieldId)\r\n const remainingFieldSelected = getters.remainingFieldFeatures[fieldId] && state.remainingFieldSelected[fieldId]\r\n\r\n if (!(atLeastOneCultivationSelected || remainingFieldSelected)) {\r\n const relevantCultivationIds = getters.relevantCultivationsByFieldId[fieldId].map(x => x.id)\r\n commit('toggleFieldId', {fieldId, relevantCultivationIds})\r\n }\r\n },\r\n toggleFieldId ({state, getters, commit, dispatch, rootState}, fieldId) {\r\n const rootDispatch = (action, payload) => dispatch(action, payload, {root: true})\r\n\r\n if (rootState.fieldRecordSystem.action.ui.planningWizard.step !== 'start') throw new Error('cannot toggle fields outside of start step')\r\n\r\n const relevantCultivationIds = getters.relevantCultivationsByFieldId[fieldId].map(x => x.id)\r\n commit('toggleFieldId', {fieldId, relevantCultivationIds})\r\n\r\n const selected = state.fieldIds.includes(fieldId)\r\n\r\n if (selected) {\r\n return rootDispatch('fieldRecordSystem/action/loadActionsForFieldForPlanning', fieldId)\r\n }\r\n },\r\n toggleAll ({state, getters, rootGetters, dispatch}) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n\r\n if (!fieldId) throw new Error('only works at field level')\r\n\r\n const {everythingSelected, hasRemainingField, remainingFieldSelected} = getters.selectionSummaryByFieldId[fieldId]\r\n\r\n const cultivationIds = getters.relevantCultivationsByFieldId[fieldId]\r\n .filter(cultivation => {\r\n const isSelected = state.selectedCultivationIds[cultivation.id] === fieldId\r\n\r\n return everythingSelected === isSelected\r\n })\r\n .map(x => x.id)\r\n\r\n if (hasRemainingField && remainingFieldSelected === everythingSelected) {\r\n cultivationIds.push(null)\r\n }\r\n\r\n return Promise.all([\r\n cultivationIds.forEach(cultivationId => {\r\n dispatch('toggleCultivationId', {fieldId, cultivationId})\r\n })\r\n ])\r\n }\r\n }\r\n}\r\n","import mutations from './mutations'\r\nimport * as actions from './actions'\r\nimport saveAction from './save-action'\r\nimport startEditingAction from './edit-action'\r\nimport * as getters from './getters'\r\n\r\nimport editBuffer from './edit-buffer'\r\n\r\nimport {actionHierarchy} from './action-hierarchy'\r\n\r\nconst state = {\r\n ui: {\r\n selection: {\r\n actionId: null,\r\n },\r\n planningWizard: {\r\n step: null,\r\n parameterStep: null,\r\n mode: null,\r\n partEditingIndex: null,\r\n },\r\n },\r\n data: {\r\n actions: {\r\n // TODO refactor, see ASK-2138\r\n forField: [],\r\n // TODO refactor, see ASK-2138\r\n forOrgUnit: [],\r\n templatesForOrgUnit: [],\r\n },\r\n editing: {\r\n actionHierarchy,\r\n // TODO refactor, see ASK-2138\r\n actionsByField: {},\r\n cultivationsByField: {},\r\n },\r\n planningWizard: {\r\n combinationParts: [],\r\n },\r\n },\r\n cultivationsForOrgUnit: {},\r\n navigationSource: null,\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n mutations,\r\n actions: {\r\n ...actions,\r\n saveAction,\r\n startEditingAction,\r\n },\r\n getters,\r\n modules: {\r\n editBuffer,\r\n },\r\n}\r\n","import axios from 'axios'\r\nimport {sortBy} from 'lodash'\r\nimport {can} from 'src/js/helpers/permissions'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport const loadMachineGroups = ({commit, rootState}) => {\r\n if (can(rootState.permissions, 'Use.Frs.Actions')) {\r\n return axios.get('/api/v2/masterdata/machine/types')\r\n .then(machineGroups => {\r\n commit('setMachineGroups', sortBy(machineGroups.data, ['rank']))\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport const loadMachines = ({rootGetters, commit, rootState}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n if (can(rootState.permissions, 'Use.Frs.Actions')) {\r\n return smarterGet('/api/v2/entities/{orgUnitId}/machines/{harvestYear}', {\r\n id: 'data.machines',\r\n expiry: 120,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n harvestYear: () => harvestYear\r\n },\r\n sharedCache: true,\r\n onResult (data) {\r\n commit('setMachines', data)\r\n }\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport const saveMachine = ({state, rootGetters, commit}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const machine = state.editBuffer\r\n machine.orgUnitId = orgUnitId\r\n return axios.post(`/api/v2/entities/${orgUnitId}/machines`, machine)\r\n .then(({data: machine}) => {\r\n commit('saveMachine', machine)\r\n })\r\n}\r\n\r\nexport const removeMachine = ({rootGetters, commit}, machine) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n return axios.delete(`/api/v2/entities/${orgUnitId}/machines/${machine.id}`)\r\n .then(() => {\r\n commit('deleteMachine', machine.id)\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\nexport const shareMachineToChilds = ({rootGetters}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n return axios.post(`/api/v2/entities/${orgUnitId}/machines/share/all`)\r\n .then(() => {\r\n })\r\n}\r\n\r\nexport const startEditing = ({commit, dispatch}, machine) => {\r\n return dispatch('loadMachineGroups')\r\n .then(() => {\r\n commit('setEditing', true)\r\n commit('editBuffer/reset', Object.assign({group: null}, machine))\r\n })\r\n}\r\n\r\nexport const stopEditing = ({commit}) => {\r\n commit('setEditing', false)\r\n}\r\n","export function setMachines (state, machines) {\r\n state.data.machines = machines\r\n}\r\n\r\nexport function setEditing (state, value) {\r\n state.ui.editing = value\r\n}\r\n\r\nexport function setMachineGroups (state, machineGroups) {\r\n state.data.machineGroups = machineGroups\r\n}\r\n\r\nexport function saveMachine (state, machine) {\r\n const existing = state.data.machines.find(m => m.id === machine.id)\r\n if (existing) {\r\n Object.assign(existing, machine)\r\n } else {\r\n state.data.machines.push(machine)\r\n }\r\n}\r\n\r\nexport function deleteMachine (state, machineId) {\r\n const index = state.data.machines.findIndex(m => m.id === machineId)\r\n if (index !== -1) {\r\n state.data.machines.splice(index, 1)\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n orgUnitId: null,\r\n name: '',\r\n group: null,\r\n vin: null,\r\n workingWidth: 0,\r\n turningCircle: 0,\r\n isRetracted: false,\r\n isArchived: false\r\n})\r\n\r\nconst checkValidity = partialMachine => {\r\n const defaultMachine = defaults()\r\n for (const key in partialMachine) {\r\n if (!(key in defaultMachine)) {\r\n console.error(`[machine editBuffer] set: property '${key}' does not exist in machine defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'id',\r\n 'name',\r\n 'vin',\r\n 'workingWidth',\r\n 'turningCircle',\r\n 'group'\r\n ]),\r\n set (state, partialMachine) {\r\n checkValidity(partialMachine)\r\n Object.assign(state, partialMachine)\r\n },\r\n reset (state, machine) {\r\n if (machine) {\r\n checkValidity(machine)\r\n }\r\n Object.assign(state, defaults(), machine)\r\n }\r\n }\r\n}\r\n","import * as actions from './actions'\r\nimport * as mutations from './mutations'\r\nimport editBuffer from './edit-buffer'\r\n\r\nconst state = {\r\n ui: {\r\n selection: {\r\n machine: null\r\n },\r\n editing: false\r\n },\r\n data: {\r\n machines: [], // usually for current orgunit\r\n machineGroups: []\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\nimport {can} from 'src/js/helpers/permissions'\r\n\r\nexport const loadPersons = ({rootGetters, commit}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n return smarterGet('/api/v2/entities/{orgUnitId}/staff/{harvestYear}', {\r\n id: 'data.persons',\r\n expiry: 120,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n harvestYear: () => harvestYear\r\n },\r\n sharedCache: true,\r\n onResult (data) {\r\n commit('setPersons', data)\r\n }\r\n })\r\n}\r\n\r\nexport const savePerson = ({state, rootGetters, commit, rootState}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const {id, name} = state.editBuffer\r\n\r\n if (can(rootState.permissions, 'Use.Frs.Actions')) {\r\n return axios.post(`/api/v2/entities/${orgUnitId}/staff`, {id, orgUnitId, name})\r\n .then(({data: person}) => {\r\n commit('savePerson', person)\r\n })\r\n } else {\r\n return Promise.resolve()\r\n }\r\n}\r\n\r\nexport const removePerson = ({rootGetters, commit}, person) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n return axios.delete(`/api/v2/entities/${orgUnitId}/staff/${person.id}`)\r\n .then(() => {\r\n commit('removePerson', person.id)\r\n commit('fieldRecordSystem/setDataLoading', false, {root: true})\r\n })\r\n}\r\n\r\nexport const sharePersonsToChilds = ({rootGetters}) => {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n return axios.post(`/api/v2/entities/${orgUnitId}/staff/share/all`)\r\n .then(() => {\r\n })\r\n}\r\n\r\nexport const startEditing = ({commit}, person) => {\r\n commit('setEditing', true)\r\n commit('editBuffer/reset', {person})\r\n}\r\n\r\nexport const stopEditing = ({commit}) => {\r\n commit('setEditing', false)\r\n}\r\n","export function setPersons (state, persons) {\r\n state.data.persons = persons\r\n}\r\n\r\nexport function setEditing (state, value) {\r\n state.ui.editing = value\r\n}\r\n\r\nexport function savePerson (state, person) {\r\n const existing = state.data.persons.find(p => p.id === person.id)\r\n if (existing) {\r\n existing.name = person.name\r\n } else {\r\n state.data.persons.push(person)\r\n }\r\n}\r\n\r\nexport function removePerson (state, personId) {\r\n const index = state.data.persons.findIndex(m => m.id === personId)\r\n if (index !== -1) {\r\n state.data.persons.splice(index, 1)\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n orgUnitId: null,\r\n name: ''\r\n})\r\n\r\nconst checkValidity = partialPerson => {\r\n const defaultPerson = defaults()\r\n for (const key in partialPerson) {\r\n if (!(key in defaultPerson)) {\r\n console.error(`[person editBuffer] set: property '${key}' does not exist in person defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'name'\r\n ]),\r\n set (state, partialPerson) {\r\n checkValidity(partialPerson)\r\n Object.assign(state, partialPerson)\r\n },\r\n reset (state, {person}) {\r\n if (person) {\r\n checkValidity(person)\r\n Object.assign(state, person)\r\n } else {\r\n Object.assign(state, defaults())\r\n }\r\n }\r\n }\r\n}\r\n","import * as actions from './actions'\r\nimport * as mutations from './mutations'\r\nimport editBuffer from './editBuffer'\r\n\r\nconst state = {\r\n ui: {\r\n selection: {\r\n person: null\r\n },\r\n editing: false\r\n },\r\n data: {\r\n persons: [] // usually for current orgunit\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","export const cloneFeatures = features => features.map(function (f) {\r\n const clone = f.clone()\r\n // clone.setId(f.getId())\r\n return clone\r\n})\r\n\r\nexport function ensureUniqueIds (features) {\r\n const ids = {}\r\n\r\n return features.map(feature => {\r\n let id = feature.properties ? feature.properties.id : 'undefined'\r\n\r\n if (id in ids) {\r\n id += `_${ids[id]++}`\r\n } else {\r\n ids[id] = 1\r\n }\r\n\r\n return {\r\n ...feature,\r\n properties: {\r\n ...feature.properties,\r\n id\r\n }\r\n }\r\n })\r\n}\r\n","import {getCenter} from 'ol/extent'\r\nimport Vue from 'vue'\r\nimport {cloneDeep} from 'lodash'\r\n\r\nimport {polyLikeFilter, splitToPolygons, geoJsonFormat} from '@helpers/openlayers/features'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport {ensureUniqueIds} from './helpers'\r\n\r\nconst assertGeoJson = features => {\r\n if (features.some(x => x.type !== 'Feature')) {\r\n throw new Error('only geojson supported')\r\n }\r\n}\r\n\r\nconst historyMove = (state, {from, to}) => {\r\n const current = {\r\n editing: cloneDeep(state.editing.activeFeatures),\r\n guides: cloneDeep(state.editing.guideFeatures)\r\n }\r\n to.push(current)\r\n\r\n const replacement = from.pop()\r\n\r\n state.editing.activeFeatures = replacement.editing\r\n state.editing.guideFeatures = replacement.guides\r\n}\r\n\r\nconst mutations = {\r\n ...makeSetters([\r\n 'layers',\r\n 'editing.abortEditing'\r\n ]),\r\n updateFabPosition (state, feature) {\r\n if (!feature) {\r\n state.fab.position = null\r\n return\r\n }\r\n\r\n state.fab.position = getCenter(feature.getGeometry().getExtent())\r\n },\r\n\r\n setGlobalAutoFit (state, value) {\r\n state.autoFit = value\r\n },\r\n setFocusExtent (state, extent) {\r\n state.focusExtent = extent\r\n },\r\n addVectorLayer (state, layer) {\r\n if (layer.id in state.layers) {\r\n throw new Error(`layer ${layer.id} already exists`)\r\n }\r\n\r\n Vue.set(state.layers, layer.id, layer)\r\n Vue.set(layer, 'styleStack', [layer.style])\r\n state.layerList = state.layerList.filter(x => x !== layer.id)\r\n state.layerList.splice(0, 0, layer.id)\r\n },\r\n removeVectorLayer (state, {id}) {\r\n Vue.delete(state.layers, id)\r\n state.layerList = state.layerList.filter(x => x !== id)\r\n },\r\n setFeatures (state, {id, features}) {\r\n console.error('[fieldRecordSystem/map/setFeatures] this mutation is deprecated')\r\n // console.trace()\r\n\r\n if (features.some(x => x.type !== 'Feature')) {\r\n // most likely ol.Feature instances\r\n features = features.map(x => geoJsonFormat.writeFeatureObject(x))\r\n }\r\n\r\n if (!state.layers[id]) {\r\n console.error(`[fieldRecordSystem/map/setFeatures] layer ${id} does not exist`)\r\n return\r\n }\r\n state.layers[id].features = features\r\n },\r\n setActiveFeatures (state, features) {\r\n assertGeoJson(features)\r\n\r\n state.editing.activeFeatures = ensureUniqueIds(features)\r\n },\r\n setGuideFeatures (state, features) {\r\n assertGeoJson(features)\r\n\r\n state.editing.guideFeatures = ensureUniqueIds(features)\r\n },\r\n pushVectorStyle (state, {id, style}) {\r\n state.layers[id].styleStack.push(style)\r\n state.layers[id].style = style\r\n },\r\n popVectorStyle (state, {id}) {\r\n const stack = state.layers[id].styleStack\r\n if (stack[0].length < 2) {\r\n throw new Error('popVectorStyle called more often than pushVectorStyle')\r\n }\r\n stack.pop()\r\n state.layers[id].style = stack[stack.length - 1]\r\n },\r\n setVectorStyle (state, {id, style}) {\r\n state.layers[id].style = style\r\n },\r\n setSelectedIds (state, ids) {\r\n state.editing.selectedIds = ids\r\n },\r\n setStyle (state, {id, style}) {\r\n state.layers[id].style = style\r\n },\r\n clear (state, id) {\r\n state.layers[id].features = []\r\n },\r\n setBingVisible (state, name) {\r\n state.bing.visible = name\r\n },\r\n // editing\r\n setEditing (state, active) {\r\n state.editing.active = active\r\n // TODO make more sophisticated, currently if you enter editing from a page where default interactions are disabled, it will be incorrect after stopping editing\r\n state.defaultInteractionsEnabled = !active\r\n },\r\n setMode (state, mode) {\r\n state.editing.mode = mode\r\n },\r\n setOriginalStyles (state, stylesDict) {\r\n state.editing.originalStyles = stylesDict\r\n },\r\n copyToClipboard (state, features) {\r\n if (features.some(x => x.type !== 'Feature')) {\r\n throw new Error('copyToClipboard only supports GeoJSON features')\r\n }\r\n\r\n state.clipboard = cloneDeep(features)\r\n },\r\n pasteAsPolygons (state, layerId) {\r\n const features = splitToPolygons(state.clipboard.map(x => geoJsonFormat.readFeature(x)).filter(polyLikeFilter))\r\n .map(feature => geoJsonFormat.writeFeatureObject(feature))\r\n\r\n if (layerId === 'guides') {\r\n state.editing.guideFeatures.push(...features)\r\n } else if (layerId === 'editing') {\r\n state.editing.activeFeatures.push(...features)\r\n } else {\r\n throw new Error(`invalid layerId: ${layerId}`)\r\n }\r\n },\r\n recordFeatures (state) {\r\n state.editing.redoBuffer = []\r\n state.editing.undoBuffer.push({\r\n editing: cloneDeep(state.editing.activeFeatures),\r\n guides: cloneDeep(state.editing.guideFeatures)\r\n })\r\n },\r\n undo (state, noRedo) {\r\n if (state.editing.undoBuffer.length) {\r\n historyMove(state, {from: state.editing.undoBuffer, to: state.editing.redoBuffer})\r\n }\r\n if (noRedo) {\r\n state.editing.redoBuffer = []\r\n }\r\n },\r\n redo (state) {\r\n if (state.editing.redoBuffer.length) {\r\n historyMove(state, {from: state.editing.redoBuffer, to: state.editing.undoBuffer})\r\n }\r\n },\r\n clearEditingHistory (state) {\r\n state.editing.undoBuffer = []\r\n state.editing.redoBuffer = []\r\n },\r\n moveLayerUp (state, {id}) {\r\n const index = state.layerList.indexOf(id)\r\n if (index > 0) {\r\n state.layerList.splice(index - 1, 2, id, state.layerList[index - 1])\r\n }\r\n },\r\n moveLayerDown (state, {id}) {\r\n const index = state.layerList.indexOf(id)\r\n if (index < state.layerList.length - 1) {\r\n state.layerList.splice(index, 2, state.layerList[index + 1], id)\r\n }\r\n }\r\n}\r\n\r\nexport default mutations\r\n","import {extend, createEmpty} from 'ol/extent'\r\n\r\nimport {geoJsonFormat, wktFormat} from '@helpers/openlayers/features'\r\n\r\nexport default ({commit}, obj) => {\r\n if (!obj) return\r\n\r\n // wkt\r\n if (typeof obj === 'string') {\r\n obj = wktFormat.readGeometry(obj, {dataProjection: 'EPSG:4326', featureProjection: 'EPSG:3857'})\r\n }\r\n\r\n // extent\r\n if (Array.isArray(obj) && obj.every(x => typeof x === 'number')) {\r\n commit('setFocusExtent', obj)\r\n return\r\n }\r\n // geojson feature\r\n if (obj.type === 'Feature' && obj.geometry) {\r\n obj = geoJsonFormat.readFeature(obj)\r\n }\r\n // geojson geometry\r\n if (obj.type && obj.coordinates) {\r\n obj = geoJsonFormat.readGeometry(obj)\r\n }\r\n // feature\r\n if (obj.getGeometry instanceof Function) {\r\n commit('setFocusExtent', obj.getGeometry().getExtent())\r\n return\r\n }\r\n // geojson feature collection\r\n if (obj.type === 'FeatureCollection' && obj.features) {\r\n obj = geoJsonFormat.readFeatures(obj)\r\n }\r\n // array of geojson features\r\n if (Array.isArray(obj) && obj.every(x => x.type === 'Feature')) {\r\n obj = obj.map(feature => geoJsonFormat.readFeature(feature))\r\n }\r\n // array of geojson geometries\r\n if (Array.isArray(obj) && obj.every(x => x.coordinates)) {\r\n obj = obj.map(geometry => geoJsonFormat.readGeometry(geometry))\r\n }\r\n // array of features\r\n if (Array.isArray(obj) && obj.every(x => x.getGeometry instanceof Function)) {\r\n const ext = obj.reduce((combined, x) => extend(combined, x.getGeometry().getExtent()), createEmpty())\r\n commit('setFocusExtent', ext)\r\n return\r\n }\r\n // layer or geometry\r\n if (obj.getExtent instanceof Function) {\r\n commit('setFocusExtent', obj.getExtent())\r\n return\r\n }\r\n // array of layer or geometry\r\n if (Array.isArray(obj) && obj.every(x => x.getExtent instanceof Function)) {\r\n const ext = obj.reduce((combined, x) => extend(combined, x.getExtent()), createEmpty())\r\n commit('setFocusExtent', ext)\r\n return\r\n }\r\n\r\n console.error('map focus can only be set for extents, layers, features or geometries, was given:')\r\n console.error(obj)\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {simplifyHighQuality} from '@helpers/geojson/simplification'\r\nimport {geoJsonFormat, dissolveMultiGeometries} from '@helpers/openlayers/features'\r\n\r\nfunction setupEditing ({commit}, features) {\r\n if (features.every(x => x.type === 'Feature')) {\r\n features = features.map(x => geoJsonFormat.readFeature(x))\r\n }\r\n\r\n features = dissolveMultiGeometries(features)\r\n\r\n commit('clearEditingHistory')\r\n commit('setEditing', true)\r\n\r\n commit('setActiveFeatures', features.map(feature => geoJsonFormat.writeFeatureObject(feature)))\r\n commit('setSelectedIds', [])\r\n}\r\n\r\nfunction setupExpertMode ({commit}) {\r\n commit('setFlavor', 'expert')\r\n commit('setShowImportSimplificationHint', false)\r\n commit('fieldRecordSystem/setEditingComponent', null, {root: true})\r\n}\r\n\r\nfunction selectSensibleDefaults ({commit, dispatch}, features) {\r\n commit('setMode', features.length ? 'edit' : 'addPolygon')\r\n return dispatch('focus', features)\r\n}\r\n\r\nexport function startQuickMode ({state, commit, dispatch}, features) {\r\n setupEditing({state, commit}, features)\r\n\r\n commit('setFlavor', 'quick')\r\n\r\n return selectSensibleDefaults({commit, dispatch}, features)\r\n}\r\n\r\nexport function switchToExpertMode ({state, commit}) {\r\n if (state.editing.flavor !== 'quick') {\r\n throw new Error('switching to expert mode only works from quick mode')\r\n }\r\n\r\n setupExpertMode({commit})\r\n}\r\n\r\nexport function startExpertMode ({state, commit, dispatch}, features) {\r\n setupEditing({state, commit}, features)\r\n\r\n setupExpertMode({commit})\r\n\r\n return selectSensibleDefaults({commit, dispatch}, features)\r\n}\r\n\r\nexport async function stopEditing ({state, commit}) {\r\n commit('setEditing', false)\r\n\r\n const features = state.editing.activeFeatures\r\n\r\n return features.map(feature => geoJsonFormat.readFeature(feature))\r\n}\r\n\r\nexport function deleteSelection ({state, commit}) {\r\n commit('recordFeatures')\r\n\r\n const unselected = feature => !state.editing.selectedIds.includes(feature.properties.id)\r\n\r\n // delete all if nothing selected (quick-mode)\r\n const activeFeatures = state.editing.selectedIds.length > 0\r\n ? state.editing.activeFeatures.filter(unselected)\r\n : []\r\n const guideFeatures = state.editing.selectedIds.length > 0\r\n ? state.editing.guideFeatures.filter(unselected)\r\n : []\r\n commit('setActiveFeatures', activeFeatures)\r\n commit('setGuideFeatures', guideFeatures)\r\n\r\n commit('setSelectedIds', [])\r\n}\r\n\r\nexport function simplifyGeometry ({state, getters, commit}) {\r\n if (!getters.selectedFeatures.length) {\r\n return\r\n }\r\n\r\n commit('recordFeatures')\r\n\r\n const otherFeatures = state.editing.activeFeatures.filter(x => !getters.selectedFeatures.includes(x))\r\n\r\n const simplified = [...getters.selectedFeatures]\r\n simplified.forEach(feature => {\r\n simplifyHighQuality(feature.geometry) // mutate inplace because features (from getter) are discarded afterwards anyways\r\n })\r\n\r\n const features = otherFeatures.concat(simplified)\r\n\r\n commit('setActiveFeatures', features)\r\n commit('setSelectedIds', [])\r\n}\r\n\r\nexport function borderRecognition ({state, commit, dispatch}, {source, coordinate: [lon, lat], featureLoadingFunction}) {\r\n if (state.borderRecognition.active) return\r\n\r\n if (featureLoadingFunction) {\r\n const features = featureLoadingFunction([lon, lat])\r\n\r\n if (features.length) {\r\n const recognizedBorder = dissolveMultiGeometries(features[0].clone())\r\n .map(feature => geoJsonFormat.writeFeatureObject(feature))\r\n\r\n const currentFeatures = state.editing.activeFeatures\r\n\r\n commit('setActiveFeatures', [...currentFeatures, ...recognizedBorder])\r\n return dispatch('enterSelectMode')\r\n }\r\n }\r\n\r\n commit('setBorderRecognitionStatus', true)\r\n\r\n const url = source === 'ixmap'\r\n ? `/api/v2/entities/fields/geodata/suggestion?longitude=${lon}&latitude=${lat}`\r\n : `/api/v2/automatic-border/${lon}/${lat}`\r\n\r\n axios.get(url)\r\n .then(response => response.data)\r\n .then(geojson => {\r\n commit('setBorderRecognitionStatus', false)\r\n\r\n if (!geojson.features.length) return false\r\n\r\n const recognizedBorder = dissolveMultiGeometries(geoJsonFormat.readFeature(geojson.features[0]))\r\n .map(feature => geoJsonFormat.writeFeatureObject(feature))\r\n\r\n const currentFeatures = state.editing.activeFeatures\r\n\r\n commit('setActiveFeatures', [...currentFeatures, ...recognizedBorder])\r\n return dispatch('enterSelectMode')\r\n })\r\n .catch(() => {\r\n commit('setBorderRecognitionStatus', false)\r\n })\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport mutations from './mutations'\r\nimport * as actions from './actions'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n bing: {\r\n visible: 'hybrid'\r\n },\r\n showDefaultLayers: true,\r\n defaultInteractionsEnabled: true,\r\n autoFit: false,\r\n focusExtent: [],\r\n layers: {},\r\n layerList: [],\r\n clipboard: [],\r\n editing: {\r\n active: false,\r\n mode: 'edit',\r\n flavor: 'quick', // or expert\r\n abortEditing: false,\r\n component: null,\r\n undoBuffer: [],\r\n redoBuffer: [],\r\n originalStyles: {},\r\n activeFeatures: [],\r\n guideFeatures: [],\r\n selectedIds: [],\r\n sharedPlugins: null,\r\n validateWhileChange: true,\r\n snapping: true,\r\n autoFit: false,\r\n roads: false,\r\n showImportSimplificationHint: false,\r\n showGeometryErrors: true\r\n },\r\n fab: { // floating action button .... it's FAB-ulous\r\n position: null\r\n },\r\n borderRecognition: {\r\n active: false\r\n }\r\n },\r\n getters: {\r\n selectedFeatures (state) {\r\n return state.editing.selectedIds.map(id => state.editing.activeFeatures.find(x => x.properties.id === id))\r\n }\r\n },\r\n mutations: {\r\n setBorderRecognitionStatus (state, value) {\r\n state.borderRecognition.active = value\r\n },\r\n ...makeSetters([\r\n 'editing.validateWhileChange',\r\n 'editing.snapping',\r\n 'editing.autoFit',\r\n 'editing.roads',\r\n 'editing.showImportSimplificationHint',\r\n 'editing.flavor',\r\n 'editing.showGeometryErrors',\r\n 'showDefaultLayers',\r\n 'defaultInteractionsEnabled'\r\n ]),\r\n ...mutations\r\n },\r\n actions\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n fieldId: null,\r\n geometry: null,\r\n mainCropId: null,\r\n mainCropNitrogenRequirement: 0,\r\n mainCropIncrease: 0,\r\n mainCropDecrease: 0,\r\n mainCropDifference: 0,\r\n previousCropId: null,\r\n catchCropId: null,\r\n harvestYear: 0,\r\n expectedYield: 0,\r\n averageYieldLast3Years: 0,\r\n yieldDifference: 0,\r\n nitrogenActual: 0,\r\n nitrogenHumusContentIsLow: true,\r\n isCovered: false,\r\n additionalRequirementFromCover: 0,\r\n nitrogenFertilizationPreviousYear: 0,\r\n nitrogenFertilizationForCalculation: 0,\r\n nitrogenRequirement: 0,\r\n phosphorusPlans: [pDefaults()],\r\n corrections: [],\r\n currentCorrection: null,\r\n supplementsAndDiscountsForYieldDifference: 0,\r\n previousCrop: null,\r\n catchCrop: null,\r\n valueFromPreviousOrCatchCrop: 0,\r\n typeOfSoil: '',\r\n cropPhosphorusRequirement: 0,\r\n mainToByproductRatio: 0,\r\n phosphorusContentByproduct: 0,\r\n totalPRevocation: 0\r\n})\r\n\r\nconst pDefaults = () => ({\r\n byproductIsRemoved: false,\r\n phosphorusContentClass: 'A',\r\n expectedYield: 0,\r\n mainCropId: null,\r\n phosphorusRequirement: 0,\r\n cropPhosphorusRequirement: 0,\r\n harvestCrop: 0,\r\n cropResidues: 0,\r\n mainToByproductRatio: 0,\r\n phosphorusContentByproduct: 0\r\n})\r\n\r\nconst defaultCorrection = () => ({\r\n id: null,\r\n amount: 0,\r\n note: ''\r\n})\r\n\r\nfunction recalculatePhosphorusValues (state, index) {\r\n state.yieldDifference = state.averageYieldLast3Years - state.phosphorusPlans[0].expectedYield\r\n\r\n const supplementsAndDiscountsCalculation = state.mainCropIncrease / state.mainCropDifference * state.yieldDifference\r\n state.supplementsAndDiscountsForYieldDifference = state.yieldDifference > 0\r\n ? (supplementsAndDiscountsCalculation > 40 ? 40 : supplementsAndDiscountsCalculation)\r\n : state.mainCropDecrease / state.mainCropDifference * state.yieldDifference\r\n\r\n // Calculation n requirement\r\n const humusNAmount = state.nitrogenHumusContentIsLow ? 0 : 20\r\n\r\n const nRequirementTemp = state.mainCropNitrogenRequirement -\r\n state.nitrogenActual +\r\n state.supplementsAndDiscountsForYieldDifference -\r\n humusNAmount -\r\n state.nitrogenFertilizationForCalculation -\r\n state.valueFromPreviousOrCatchCrop\r\n\r\n state.nitrogenRequirement = nRequirementTemp > 0 ? nRequirementTemp : 0\r\n\r\n const harvestCropTemp = (index === 0 ? state.averageYieldLast3Years : state.phosphorusPlans[index].expectedYield) * state.phosphorusPlans[index].cropPhosphorusRequirement\r\n state.phosphorusPlans[index].harvestCrop = harvestCropTemp > 0 ? harvestCropTemp : 0\r\n\r\n const cropResiduesTemp = (index === 0 ? state.averageYieldLast3Years : state.phosphorusPlans[index].expectedYield) * state.phosphorusPlans[index].mainToByproductRatio * state.phosphorusPlans[index].phosphorusContentByproduct\r\n state.phosphorusPlans[index].cropResidues = cropResiduesTemp > 0 ? cropResiduesTemp : 0\r\n\r\n const pRequirementTemp = state.phosphorusPlans[index].byproductIsRemoved ? state.phosphorusPlans[index].harvestCrop + state.phosphorusPlans[index].cropResidues : state.phosphorusPlans[index].harvestCrop\r\n state.phosphorusPlans[index].phosphorusRequirement = pRequirementTemp > 0 ? pRequirementTemp : 0\r\n\r\n state.totalPRevocation = state.phosphorusPlans.reduce((acc, val) => acc + val.phosphorusRequirement, 0)\r\n}\r\n\r\nconst mutations = {\r\n ...makeSetters([\r\n 'isCovered',\r\n 'currentCorrection'\r\n ]),\r\n setSupplementsAndDiscountsForYieldDifference (state, value) {\r\n state.supplementsAndDiscountsForYieldDifference = value\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setAverageYieldLast3Years (state, value) {\r\n state.averageYieldLast3Years = value\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setNitrogenFertilizationPreviousYear (state, value) {\r\n state.nitrogenFertilizationPreviousYear = value\r\n state.nitrogenFertilizationForCalculation = value * 0.1\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setNHumusContentIsLow (state, value) {\r\n state.nitrogenHumusContentIsLow = value\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setNitrogenActual (state, value) {\r\n state.nitrogenActual = value\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setAdditionalRequirementFromCover (state, value) {\r\n state.additionalRequirementFromCover = value\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setMainCropDetails (state, mainCrop) {\r\n const name = mainCrop ? mainCrop.name : null\r\n const expectedYield = mainCrop ? mainCrop.expectedYield : 0\r\n const cropPhosphorusRequirement = mainCrop ? mainCrop.phosphorusRequirement : 0\r\n const mainToByproductRatio = mainCrop ? mainCrop.mainToByproductRatio : 0\r\n const phosphorusContentByproduct = mainCrop ? mainCrop.phosphorusContentByproduct : 0\r\n const mainCropNitrogenRequirement = mainCrop ? mainCrop.nitrogenRequirement : 0\r\n const mainCropIncrease = mainCrop ? mainCrop.increase : 0\r\n const mainCropDecrease = mainCrop ? mainCrop.decrease : 0\r\n const mainCropDifference = mainCrop ? mainCrop.difference : 0\r\n\r\n state.mainCropId = name\r\n state.phosphorusPlans[0].mainCropId = name\r\n // In the future, this should be the expected yield from the previous 3 years\r\n state.averageYieldLast3Years = expectedYield\r\n\r\n state.expectedYield = expectedYield\r\n state.phosphorusPlans[0].expectedYield = expectedYield\r\n\r\n state.cropPhosphorusRequirement = cropPhosphorusRequirement\r\n state.phosphorusPlans[0].cropPhosphorusRequirement = cropPhosphorusRequirement\r\n state.phosphorusPlans[0].harvestCrop = expectedYield * cropPhosphorusRequirement\r\n\r\n state.mainToByproductRatio = mainToByproductRatio\r\n state.phosphorusPlans[0].mainToByproductRatio = mainToByproductRatio\r\n\r\n state.phosphorusContentByproduct = phosphorusContentByproduct\r\n state.phosphorusPlans[0].phosphorusContentByproduct = phosphorusContentByproduct\r\n\r\n state.mainCropNitrogenRequirement = mainCropNitrogenRequirement\r\n\r\n state.mainCropIncrease = mainCropIncrease\r\n\r\n state.mainCropDecrease = mainCropDecrease\r\n\r\n state.mainCropDifference = mainCropDifference\r\n\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setPreviousCrop (state, previousCrop) {\r\n state.previousCrop = previousCrop\r\n state.previousCropId = previousCrop ? previousCrop.value : null\r\n state.valueFromPreviousOrCatchCrop = previousCrop ? previousCrop.amount : 0\r\n\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n setCatchCrop (state, catchCrop) {\r\n state.catchCrop = catchCrop\r\n state.catchCropId = catchCrop ? catchCrop.value : null\r\n state.valueFromPreviousOrCatchCrop = catchCrop ? catchCrop.amount : 0\r\n\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n set (state, partialNutrientRequirement) {\r\n const defaultNutrientRequirement = defaults()\r\n for (const key in partialNutrientRequirement) {\r\n if (!(key in defaultNutrientRequirement)) {\r\n console.error(`[nutrient requirement editBuffer] set: property '${key}' does not exist in nutrient requirement defaults`)\r\n }\r\n }\r\n Object.assign(state, partialNutrientRequirement)\r\n\r\n if (partialNutrientRequirement.mainCropId) {\r\n state.phosphorusPlans[0].mainCropId = state.mainCropId\r\n }\r\n if (partialNutrientRequirement.nitrogenFertilizationPreviousYear) {\r\n state.nitrogenFertilizationForCalculation = partialNutrientRequirement.nitrogenFertilizationPreviousYear * 0.1\r\n }\r\n if (partialNutrientRequirement.expectedYield) {\r\n state.phosphorusPlans[0].expectedYield = state.expectedYield\r\n }\r\n if (partialNutrientRequirement.cropPhosphorusRequirement) {\r\n state.phosphorusPlans[0].cropPhosphorusRequirement = state.cropPhosphorusRequirement\r\n state.phosphorusPlans[0].harvestCrop = state.expectedYield * state.cropPhosphorusRequirement\r\n }\r\n if (partialNutrientRequirement.mainToByproductRatio) {\r\n state.phosphorusPlans[0].mainToByproductRatio = state.mainToByproductRatio\r\n }\r\n if (partialNutrientRequirement.phosphorusContentByproduct) {\r\n state.phosphorusPlans[0].phosphorusContentByproduct = state.phosphorusContentByproduct\r\n }\r\n\r\n recalculatePhosphorusValues(state, 0)\r\n },\r\n\r\n setPartialPPlan (state, {i, partialPhosphorusPlan}) {\r\n const defaultAction = pDefaults()\r\n for (const key in partialPhosphorusPlan) {\r\n if (!(key in defaultAction)) {\r\n console.error(`[nutrient requirement editBuffer] set: property '${key}' does not exist in nutrient requirement pDefaults`)\r\n }\r\n }\r\n Object.assign(state.phosphorusPlans[i], partialPhosphorusPlan)\r\n recalculatePhosphorusValues(state, i)\r\n },\r\n reset (state, nutrientRequirement) {\r\n Object.assign(state, defaults(), nutrientRequirement)\r\n },\r\n addYear (state) {\r\n if (state.phosphorusPlans.length === 3) return\r\n\r\n state.phosphorusPlans.push(pDefaults())\r\n\r\n for (let i = 0; i < state.phosphorusPlans.length; i++) {\r\n if (i !== 0) {\r\n state.phosphorusPlans[i].phosphorusContentClass = state.phosphorusPlans[0].phosphorusContentClass\r\n }\r\n recalculatePhosphorusValues(state, i)\r\n }\r\n },\r\n removeYear (state, i) {\r\n if (i < 1 || i > 2) return\r\n\r\n state.phosphorusPlans = state.phosphorusPlans.slice(0, i)\r\n\r\n for (let i = 0; i < state.phosphorusPlans.length; i++) {\r\n recalculatePhosphorusValues(state, i)\r\n }\r\n },\r\n updateYear (state, {i, plan}) {\r\n state.phosphorusPlans.splice(i, 1, plan)\r\n\r\n if (i === 0) {\r\n state.expectedYield = plan.expectedYield\r\n state.mainCropId = plan.mainCropId\r\n }\r\n recalculatePhosphorusValues(state, i)\r\n },\r\n addCorrection (state) {\r\n state.currentCorrection = defaultCorrection()\r\n },\r\n updatePhosphorusContent (state, {plan}) {\r\n let tempPlan = null\r\n\r\n for (let i = 0; i < state.phosphorusPlans.length; i++) {\r\n tempPlan = state.phosphorusPlans[i]\r\n tempPlan.phosphorusContentClass = plan.phosphorusContentClass\r\n state.phosphorusPlans.splice(i, 1, tempPlan)\r\n recalculatePhosphorusValues(state, i)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations\r\n}\r\n","import Vue from 'vue'\r\n\r\nexport function setNutrientRequirementsForField (state, nutrientRequirements) {\r\n for (const fieldId in nutrientRequirements) {\r\n Vue.set(state.data.field, fieldId, nutrientRequirements[fieldId])\r\n }\r\n}\r\n\r\nexport function setCorrections (state, {fieldId, id, corrections}) {\r\n state.data.field[fieldId].find(x => x.id === id).corrections = corrections\r\n}\r\n\r\nexport function addCorrection (state, {fieldId, nutrientRequirementId, correction}) {\r\n const correctionsTemp = state.data.field[fieldId].find(x => x.id === nutrientRequirementId).corrections\r\n const correctionTemp = correctionsTemp.find(x => x.id === correction.id)\r\n\r\n let index = -1\r\n\r\n if (correctionTemp) index = correctionsTemp.map(x => x.id).indexOf(correctionTemp.id)\r\n\r\n if (index >= 0) state.data.field[fieldId].find(x => x.id === nutrientRequirementId).corrections.splice(index, 1, correction)\r\n else state.data.field[fieldId].find(x => x.id === nutrientRequirementId).corrections.push(correction)\r\n}\r\n\r\nexport function setCrops (state, crops) {\r\n state.data.editing.crops = crops\r\n}\r\n\r\nexport function setCatchCrops (state, crops) {\r\n state.data.editing.catchCrops = crops\r\n}\r\n\r\nexport function setPreviousCrops (state, crops) {\r\n state.data.editing.previousCrops = crops\r\n}\r\n\r\nexport function addPRequirement (state, {index, value}) {\r\n let tempPlan = state.editBuffer.phosphorusPlans[index]\r\n tempPlan.phosphorusRequirement = value\r\n state.editBuffer.phosphorusPlans.splice(index, 1, tempPlan)\r\n}\r\n\r\nexport function editCorrection (state, correction) {\r\n state.editBuffer.currentCorrection = correction\r\n}\r\n\r\nexport function setStep (state, step) {\r\n state.ui.wizardStep = step\r\n}\r\n","import axios from 'axios'\r\nimport {orderBy} from 'lodash'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport async function getNutrientRequirement ({rootState, rootGetters, commit, dispatch}) {\r\n await Promise.all([\r\n dispatch('loadCrops'),\r\n dispatch('loadPreviousCrops'),\r\n dispatch('loadCatchCrops')\r\n ])\r\n\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const url = `/api/v2/nutrient-requirements/${fieldId}/${harvestYear}`\r\n const nutrientRequirements = await axios.get(url).then(response => response.data)\r\n\r\n if (Object.values(nutrientRequirements).filter(x => x.harvestYear === harvestYear).length > 0) {\r\n commit('setStep', 'overview')\r\n } else {\r\n const fieldInfo = rootState.fieldRecordSystem.data.field[fieldId]\r\n let soilType = ''\r\n\r\n if (fieldInfo) {\r\n soilType = fieldInfo.soil ? fieldInfo.soil.soilType : null\r\n }\r\n const partialNutrientRequirement = {\r\n 'harvestYear': harvestYear,\r\n 'fieldId': fieldId,\r\n 'typeOfSoil': soilType\r\n }\r\n commit('editBuffer/set', partialNutrientRequirement)\r\n commit('setStep', 'stepNitrogen')\r\n }\r\n\r\n commit('setNutrientRequirementsForField', {[fieldId]: nutrientRequirements})\r\n commit('fieldRecordSystem/setRightView', 'nutrientRequirement', {root: true})\r\n}\r\n\r\nexport function loadCrops ({commit}) {\r\n return smarterGet('/api/v2/crops/nrc', {\r\n id: 'nrc.crops.main',\r\n expiry: 3600,\r\n onResult (crops) {\r\n let transformedCrops = orderBy(crops.map(crop => {\r\n const {\r\n KULTURNAME: name,\r\n ERTRAGSNIVEAU: expectedYield,\r\n STICKSTOFFBEDARFSWERT: nitrogenRequirement,\r\n P2O5_ENTZUEGE: phosphorusRequirement,\r\n DIFFERENZ: difference,\r\n ZUSCHLAEGE: increase,\r\n ABSCHLAEGE: decrease,\r\n ERNTERESTE_P2O5: phosphorusContentByproduct,\r\n HNV: mainToByproductRatio\r\n } = crop\r\n\r\n return {\r\n name,\r\n expectedYield,\r\n nitrogenRequirement,\r\n phosphorusRequirement,\r\n phosphorusContentByproduct,\r\n difference,\r\n increase,\r\n decrease,\r\n mainToByproductRatio\r\n }\r\n }), [x => x.name])\r\n\r\n commit('setCrops', transformedCrops)\r\n }\r\n })\r\n}\r\n\r\nexport function loadPreviousCrops ({commit}) {\r\n return smarterGet('/api/v2/crops/previous', {\r\n id: 'nrc.crops.previous',\r\n expiry: 3600,\r\n onResult (crops) {\r\n let transformedCrops = orderBy(crops.map(crop => {\r\n const {\r\n VORFRUCHT: name,\r\n MINDESTABSCHLAG_KG_N_HA: minimumReduction\r\n } = crop\r\n\r\n return {\r\n name,\r\n minimumReduction\r\n }\r\n }), [x => x.name])\r\n\r\n const lookup = {}\r\n\r\n transformedCrops.forEach(crop => {\r\n lookup[crop.name] = crop.minimumReduction\r\n })\r\n\r\n commit('setPreviousCrops', lookup)\r\n }\r\n })\r\n}\r\n\r\nexport function loadCatchCrops ({commit}) {\r\n return smarterGet('/api/v2/crops/catch', {\r\n id: 'nrc.crops.catch',\r\n expiry: 3600,\r\n onResult (crops) {\r\n let transformedCrops = orderBy(crops.map(crop => {\r\n const {\r\n VORFRUCHT: name,\r\n MINDESTABSCHLAG_KG_N_HA: minimumReduction\r\n } = crop\r\n\r\n return {\r\n name,\r\n minimumReduction\r\n }\r\n }), [x => x.name])\r\n\r\n const lookup = {}\r\n\r\n transformedCrops.forEach(crop => {\r\n lookup[crop.name] = crop.minimumReduction\r\n })\r\n\r\n commit('setCatchCrops', lookup)\r\n }\r\n })\r\n}\r\n\r\nexport function stopPlanning ({commit}) {\r\n commit('editBuffer/reset')\r\n}\r\n\r\nconst getNutrientRequirementId = rootState => {\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n const fieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n\r\n const nutrientRequirement = rootState.fieldRecordSystem.nutrientRequirement.data.field[fieldId].find(x => x.harvestYear === harvestYear)\r\n\r\n return nutrientRequirement ? nutrientRequirement.id : null\r\n}\r\n\r\nexport function saveCorrection ({state, commit, rootState}) {\r\n const correction = {...state.editBuffer.currentCorrection}\r\n const nutrientRequirementId = getNutrientRequirementId(rootState)\r\n const fieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const url = `/api/v2/nutrient-requirements/${nutrientRequirementId}/corrections/${harvestYear}`\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n return axios.post(url, correction)\r\n .then(res => res.data)\r\n .then((id) => {\r\n correction.id = id\r\n commit('addCorrection', {fieldId, nutrientRequirementId, correction})\r\n })\r\n}\r\n\r\nexport function deleteCorrection ({commit, dispatch, rootState}, {id}) {\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const url = `/api/v2/nutrient-requirements/${getNutrientRequirementId(rootState)}/${id}/${harvestYear}`\r\n\r\n commit('fieldRecordSystem/setDataLoading', true, {root: true})\r\n return axios.delete(url)\r\n .then(() => dispatch('reloadCorrections'))\r\n}\r\n\r\nexport function reloadCorrections ({commit, rootState}) {\r\n const nutrientRequirementId = getNutrientRequirementId(rootState)\r\n const fieldId = rootState.fieldRecordSystem.navigation.location.fieldId\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n if (nutrientRequirementId) {\r\n const url = `/api/v2/nutrient-requirements/${getNutrientRequirementId(rootState)}/corrections/${harvestYear}`\r\n return axios.get(url)\r\n .then(res => res.data)\r\n .then(corrections =>\r\n commit('setCorrections', {fieldId, id: nutrientRequirementId, corrections}))\r\n }\r\n}\r\n\r\nexport async function saveRequirements ({state, dispatch, rootGetters, rootState}) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const geometry = (await axios.get(`/api/v2/entities/fields/${fieldId}/geodata/${harvestYear}`)).data\r\n const url = `/api/v2/nutrient-requirements/${fieldId}/${harvestYear}`\r\n const buffer = state.editBuffer\r\n const nutrientRequirements = []\r\n\r\n for (let i = 0; i < buffer.phosphorusPlans.length; i++) {\r\n let data = {\r\n id: null,\r\n fieldId: fieldId,\r\n geometry: geometry,\r\n mainCropId: i === 0 ? buffer.mainCropId : buffer.phosphorusPlans[i].mainCropId,\r\n lastCropId: i === 1 ? buffer.mainCropId : buffer.lastCropId,\r\n catchCropId: i === 0 ? buffer.catchCropId : null,\r\n harvestYear: buffer.harvestYear + i,\r\n expectedYield: buffer.phosphorusPlans[i].expectedYield,\r\n averageYieldLast3Years: i === 0 ? buffer.averageYieldLast3Years : 0,\r\n nitrogenActual: i === 0 ? buffer.nitrogenActual : 0,\r\n nitrogenHumusContentIsLow: i === 0 ? buffer.nitrogenHumusContentIsLow : false,\r\n isCovered: i === 0 ? buffer.isCovered : false,\r\n additionalRequirementFromCover: i === 0 ? buffer.additionalRequirementFromCover : 0,\r\n nitrogenFertilizationPreviousYear: i === 0 ? buffer.nitrogenFertilizationPreviousYear : 0,\r\n byproductIsRemoved: buffer.phosphorusPlans[i].byproductIsRemoved,\r\n phosphorusContentClass: buffer.phosphorusPlans[0].phosphorusContentClass,\r\n nitrogenRequirement: i === 0 ? buffer.nitrogenRequirement : 0,\r\n phosphorusRequirement: buffer.phosphorusPlans[i].phosphorusRequirement\r\n }\r\n\r\n nutrientRequirements.push(data)\r\n }\r\n\r\n return axios.post(url, nutrientRequirements)\r\n .then(() => dispatch('stopPlanning'))\r\n .then(() => dispatch('getNutrientRequirement'))\r\n}\r\n","export default {\r\n next ({state, commit}) {\r\n switch (state.ui.wizardStep) {\r\n case 'stepNitrogen':\r\n commit('setStep', 'stepPhosphorus')\r\n break\r\n case 'stepPhosphorus':\r\n commit('setStep', 'result')\r\n break\r\n }\r\n },\r\n back ({state, commit}) {\r\n switch (state.ui.wizardStep) {\r\n case 'stepPhosphorus':\r\n commit('setStep', 'stepNitrogen')\r\n break\r\n case 'result':\r\n commit('setStep', 'stepPhosphorus')\r\n break\r\n }\r\n },\r\n cancel ({commit}) {\r\n commit('editBuffer/reset')\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n }\r\n}\r\n","import editBuffer from './edit-buffer'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as mutations from './mutations'\r\nimport * as actions from './actions'\r\nimport wizardActions from './wizard-actions'\r\n\r\nconst state = {\r\n data: {\r\n field: {},\r\n editing: {\r\n harvestActions: [],\r\n crops: [],\r\n catchCrops: [],\r\n previousCrops: []\r\n }\r\n },\r\n ui: {\r\n wizardStep: 'stepNitrogen'\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n mutations: {\r\n ...mutations,\r\n ...makeSetters([\r\n 'ui.wizardStep'\r\n ])\r\n },\r\n actions: {\r\n ...actions,\r\n ...wizardActions\r\n },\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import moment from 'moment'\r\nimport Vue from 'vue'\r\n\r\nexport function setNutrientMaps (state, {fieldId, nutrientMaps}) {\r\n Vue.set(state.data.nutrientMaps, fieldId, nutrientMaps)\r\n}\r\n\r\nexport function initializeOrder (state, probingSites) {\r\n state.data.order.name = ''\r\n state.data.order.created = moment().utc().toISOString()\r\n state.data.order.probingSites = probingSites\r\n}\r\n\r\nexport function generateGeometry (state, {entityNameLookup}) {\r\n const probingSites = state.data.order.probingSites\r\n\r\n // const compare = ({coordinates: [lon1, lat1]}, {coordinates: [lon2, lat2]}) => {\r\n // // return (0.75 * (lat2 - lat1) + 0.25 * (lon1 - lon2)) // weighted NS -> WE\r\n // return (lat2 - lat1) || (lon1 - lon2) // NS -> WE\r\n // }\r\n const compare = ({geometry: wkt1}, {geometry: wkt2}) => wkt1.localeCompare(wkt2)\r\n const sortedProbingSites = probingSites.filter(x => x.isActive && state.orderCreation.fieldIds.includes(x.fieldId)).sort(compare)\r\n\r\n state.data.order.geometries = sortedProbingSites\r\n .map(({geometry, label, fieldId}, i) => ({\r\n fieldId,\r\n sampleId: state.ui.useCustomIds ? label : (i + 1).toString(),\r\n geometry: geometry,\r\n fieldName: entityNameLookup[fieldId],\r\n active: true\r\n }))\r\n}\r\n\r\nexport function updateOrderName (state, name) {\r\n state.data.order.name = name\r\n}\r\n\r\nexport function updateZoneMaps (state, {fieldId, zoneMaps}) {\r\n Vue.set(state.data.zoneMapIdsByFieldId, fieldId, zoneMaps.map(x => x.id))\r\n\r\n for (const zoneMap of zoneMaps) {\r\n if (!state.data.zoneMaps[zoneMap.id]) {\r\n Vue.set(state.data.zoneMaps, zoneMap.id, zoneMap)\r\n }\r\n }\r\n}\r\n\r\nexport function updateZoneMapDetails (state, {zoneMapId, details}) {\r\n state.data.zoneMaps[zoneMapId] = {...state.data.zoneMaps[zoneMapId], ...details}\r\n}\r\n\r\nexport function updateDefaultYields (state, {fieldId, defaultYields}) {\r\n Vue.set(state.applicationMaps.creation.defaultYieldsByFieldId, fieldId, defaultYields)\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport function startBasicFertilization ({commit, rootGetters, dispatch}) {\r\n return Promise.all([\r\n dispatch('i18n/preloadTranslations', ['bf'], {root: true}),\r\n dispatch('loadStatistics'),\r\n dispatch('loadSimplifiedFieldGeometriesForCurrentOrgUnit'),\r\n // depending on cultivationPlanning is actually quite terrible, but FrsFieldSelection does so anyways\r\n dispatch('fieldRecordSystem/cultivationPlanning/reloadCultivationsForOrgUnit', null, {root: true})\r\n ]).then(() => commit('fieldRecordSystem/setRightView', 'basicFertilization', {root: true}))\r\n}\r\n\r\nexport async function navigateToStartPage ({commit, dispatch}) {\r\n await dispatch('loadStatistics')\r\n commit('fieldRecordSystem/setRightView', 'basicFertilization', {root: true})\r\n}\r\n\r\nexport function loadSimplifiedFieldGeometriesForCurrentOrgUnit ({state, getters, commit, rootState, rootGetters}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n if (!orgUnitId) return\r\n const visibleOnly = rootGetters['fieldRecordSystem/entityLookup'][orgUnitId].visibleOnly\r\n if (visibleOnly) {\r\n commit('setSimplifiedGeometries', null)\r\n return\r\n }\r\n\r\n return smarterGet('/api/v2/entities/orgunits/{orgUnitId}/fields/simplified-geodata/{harvestYear}', {\r\n id: 'orgUnit.basic-fertilization.simplified-geometries',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n harvestYear: () => harvestYear\r\n },\r\n async onResult (geometryLookup) {\r\n commit('setSimplifiedGeometries', geometryLookup)\r\n },\r\n subtreeInclusive: true\r\n })\r\n}\r\n\r\nexport function loadStatistics ({rootGetters, commit}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootGetters['fieldRecordSystem/harvestYear']\r\n\r\n return smarterGet([\r\n '/api/v2/base-fertilization/fields/{orgUnitId}/statistics/{harvestYear}'\r\n ], {\r\n id: 'bf.field.statistics',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n harvestYear: () => harvestYear\r\n },\r\n onResult (result) {\r\n commit('setFieldStatisticsLookup', result[0])\r\n }\r\n })\r\n}\r\n\r\nexport function createNewOrder ({commit, rootGetters, dispatch}) {\r\n return dispatch('fieldRecordSystem/basicFertilization/planning/reloadProbingSitesForOrgUnit', null, {root: true})\r\n .then(probingSite => {\r\n commit('initializeOrder', probingSite)\r\n commit('orderCreation/setFieldIds', [])\r\n commit('generateGeometry', {entityNameLookup: rootGetters['fieldRecordSystem/entityNameLookup']})\r\n commit('fieldRecordSystem/setRightView', 'samplingOrderCreation', {root: true})\r\n })\r\n}\r\n\r\nexport function saveOrder ({state, dispatch, rootGetters}, order) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n return axios.post(`/api/v2/entities/orgunits/${orgUnitId}/base-fertilization/orders`, order || state.data.order)\r\n .then(response => response.data)\r\n .then(({id}) => {\r\n dispatch('exportOrders', id)\r\n })\r\n}\r\n\r\nexport function exportOrders ({commit, rootGetters}, id) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n // get open orders from server\r\n return axios.get(`/api/v2/entities/orgunits/${orgUnitId}/base-fertilization/orders/open`)\r\n .then(res => res.data)\r\n .then(orders => {\r\n commit('orderExport/setOpenOrders', orders)\r\n\r\n if (id) {\r\n commit('orderExport/setSelectedOrder', orders.find(x => x.id === id) || null)\r\n } else if (orders.length) {\r\n commit('orderExport/setSelectedOrder', orders[0])\r\n }\r\n\r\n commit('fieldRecordSystem/setRightView', 'probingOrderExport', {root: true})\r\n })\r\n}\r\n\r\nexport function startNutrientMapDisplay ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'nutrientMapDisplay', {root: true})\r\n}\r\n","import axios from 'axios'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n order: null\r\n },\r\n mutations: {\r\n createNewOrder (state) {\r\n state.order = {\r\n name: '',\r\n selectedFieldIds: []\r\n }\r\n },\r\n ...makeSetters([\r\n 'order.name',\r\n 'order.selectedFieldIds'\r\n ]),\r\n setOrderName (state, name = '') {\r\n state.order.name = name\r\n }\r\n },\r\n actions: {\r\n startOrderCreation ({commit}) {\r\n commit('createNewOrder')\r\n commit('fieldRecordSystem/setRightView', 'samplingOrderCreation', {root: true})\r\n },\r\n saveOrder ({state, rootGetters, dispatch}, continueToNextStep) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n return axios.post(`/api/v2/base-fertilization/orgunits/${orgUnitId}/orders`, state.order)\r\n .then(response => response.data)\r\n .then(({id}) => {\r\n if (continueToNextStep) {\r\n return dispatch('fieldRecordSystem/basicFertilization/orderPlanning/startOrderPlanning', id, {root: true})\r\n } else {\r\n return dispatch('fieldRecordSystem/basicFertilization/startBasicFertilization', null, {root: true})\r\n }\r\n })\r\n }\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {cloneDeep, uniq, uniqBy} from 'lodash'\r\n\r\nconst getFlattenedProbingSites = (state, key) => cloneDeep(Object.entries(state.probingSitesByFieldId)\r\n .reduce((all, [fieldId, probingSites]) => all.concat(probingSites[key].map(probingSite => ({...probingSite, fieldId}))), []))\r\n\r\nexport async function startOrderPlanning ({rootState, commit, rootGetters}, orderId) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n await Promise.all([\r\n axios.get(`/api/v2/base-fertilization/orgunits/${orgUnitId}/orders/incomplete`).then(response => response.data),\r\n axios.get(`/api/v2/base-fertilization/orgunits/${orgUnitId}/probing-sites/${harvestYear}/by-field`).then(response => response.data)\r\n ])\r\n .then(([orders, probingSitesByFieldId]) => {\r\n commit('setIncompleteOrders', orders)\r\n\r\n commit('setProbingSitesByFieldId', probingSitesByFieldId)\r\n\r\n if (orderId) {\r\n commit('setSelectedOrderId', orders.find(x => x.id === orderId).id)\r\n }\r\n })\r\n\r\n commit('fieldRecordSystem/setRightView', 'samplingOrderPlanning', {root: true})\r\n}\r\n\r\nexport function cancelOrderPlanning ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'basicFertilization', {root: true})\r\n}\r\n\r\nexport async function saveOrder ({state, getters, commit, dispatch, rootGetters}, continueToNextStep) {\r\n commit('finishField')\r\n\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const entityNameLookup = rootGetters['fieldRecordSystem/entityNameLookup']\r\n const selectedOrder = getters['selectedOrder']\r\n\r\n const deletedIds = uniq(getFlattenedProbingSites(state, 'deleted')).map(x => x.id)\r\n const existingProbingSites = uniqBy(getFlattenedProbingSites(state, 'existing'), 'id').filter(probingSite => selectedOrder.selectedFieldIds.includes(probingSite.fieldId))\r\n\r\n const added = getFlattenedProbingSites(state, 'new').filter(probingSite => !deletedIds.includes(probingSite.id))\r\n\r\n added.forEach(probingSite => {\r\n probingSite.id = null // NOTE proper id is generated server-side on save\r\n })\r\n\r\n const updated = existingProbingSites.filter(probingSite => !deletedIds.includes(probingSite.id))\r\n const deleted = existingProbingSites.filter(probingSite => deletedIds.includes(probingSite.id))\r\n const planningProbingSites = {added, updated, deleted}\r\n const addedIds = await axios.post(`/api/v2/base-fertilization/orgunits/${orgUnitId}/probing-sites`, planningProbingSites)\r\n .then(response => response.data)\r\n\r\n addedIds.forEach((id, i) => {\r\n added[i].id = id // NOTE add server-generated id to each new probingSite\r\n })\r\n\r\n const samplingOrderGeometries = added\r\n .concat(updated)\r\n .filter(x => x.isActive)\r\n .map(({geometry, label, fieldIds, fieldId}) => {\r\n const fieldNames = fieldIds && fieldIds\r\n .filter(id => selectedOrder.selectedFieldIds.includes(id))\r\n .map(fieldId => entityNameLookup[fieldId])\r\n .join(', ')\r\n\r\n const fieldName = entityNameLookup[fieldId]\r\n\r\n return {\r\n sampleId: label,\r\n geometry: geometry,\r\n fieldName: fieldNames || fieldName\r\n }\r\n })\r\n\r\n await axios.put(`/api/v2/base-fertilization/orders/${state.selectedOrderId}/geometries`, samplingOrderGeometries)\r\n\r\n if (continueToNextStep) {\r\n return dispatch('fieldRecordSystem/basicFertilization/exportOrders', null, {root: true})\r\n } else {\r\n return dispatch('fieldRecordSystem/basicFertilization/startBasicFertilization', null, {root: true})\r\n }\r\n}\r\n","let counter = 0\r\n\r\nfunction reset (state, hard) {\r\n state.selectedZoneMapId = null\r\n state.selectedFieldId = null\r\n state.probingSites = {\r\n existing: [],\r\n new: [],\r\n deleted: []\r\n }\r\n state.probingSiteMode = 'probingPoints'\r\n\r\n if (hard) {\r\n state.selectedOrderId = null\r\n state.fieldIds = []\r\n }\r\n}\r\n\r\nexport function setShowNumbers (state, boolean) {\r\n state.showNumbers = boolean\r\n}\r\n\r\nexport function setProbingSitesByFieldId (state, probingSitesByFieldId) {\r\n const lookup = {}\r\n for (const fieldId in probingSitesByFieldId) {\r\n probingSitesByFieldId[fieldId].forEach(probingSite => {\r\n probingSite.isActive = false\r\n })\r\n\r\n lookup[fieldId] = {\r\n existing: probingSitesByFieldId[fieldId],\r\n new: [],\r\n deleted: []\r\n }\r\n }\r\n state.probingSitesByFieldId = lookup\r\n}\r\n\r\nexport function finishField (state) {\r\n if (state.selectedFieldId) {\r\n state.probingSitesByFieldId = {\r\n ...state.probingSitesByFieldId,\r\n [state.selectedFieldId]: state.probingSites\r\n }\r\n }\r\n\r\n reset(state)\r\n}\r\n\r\nexport function setIncompleteOrders (state, orders) {\r\n reset(state, true)\r\n\r\n state.incompleteOrders = orders\r\n}\r\n\r\nexport function setSelectedOrderId (state, orderId) {\r\n reset(state, true)\r\n\r\n state.selectedOrderId = orderId\r\n}\r\n\r\nexport function setSelectedFieldId (state, fieldId) {\r\n finishField(state)\r\n\r\n Object.assign(state.probingSites, state.probingSitesByFieldId[fieldId])\r\n\r\n state.selectedFieldId = fieldId\r\n}\r\n\r\nexport const addNewProbingSite = (state, wkt) => {\r\n const labels = state.probingSites.new.concat(state.probingSites.existing).map(x => Number(x.label)).filter(x => x)\r\n\r\n let nextLabel = 1\r\n while (labels.includes(nextLabel)) {\r\n nextLabel++\r\n }\r\n\r\n state.probingSites.new.push({id: counter++, geometry: wkt, label: `${nextLabel}`, isActive: true})\r\n}\r\n\r\nexport const renameProbingSite = (state, {id, label}) => {\r\n const probingSite = state.probingSites.new.concat(state.probingSites.existing).find(x => x.id === id)\r\n probingSite.label = label\r\n}\r\n\r\nexport const toggleActive = (state, {id}) => {\r\n Object.values(state.probingSitesByFieldId).map(probingSites => probingSites.existing\r\n .find(existing => existing.id === id))\r\n .filter(x => x)\r\n .map(convertProbingSite => {\r\n convertProbingSite.isActive = !convertProbingSite.isActive\r\n })\r\n}\r\n\r\nexport function setActiveForAll (state, isActive) {\r\n const geometryType = state.probingSiteMode === 'probingPoints' ? 'POINT' : 'LINESTRING'\r\n\r\n for (const key in state.probingSites) {\r\n for (const probingSite of state.probingSites[key].filter(x => x.geometry.startsWith(geometryType))) {\r\n probingSite.isActive = isActive\r\n }\r\n }\r\n}\r\n\r\nexport const toggleDeletion = (state, {id}) => {\r\n const probingSites = state.probingSites\r\n\r\n if (probingSites.deleted.map(x => x.id).includes(id)) {\r\n probingSites.deleted = probingSites.deleted.filter(x => x.id !== id)\r\n } else {\r\n probingSites.deleted.push(probingSites.existing.concat(probingSites.new).find(x => x.id === id))\r\n }\r\n}\r\n\r\nexport const setSelectedZoneMapId = (state, zoneMapId) => {\r\n state.selectedZoneMapId = zoneMapId\r\n}\r\n\r\nexport const setProbingSiteMode = (state, mode) => {\r\n state.probingSiteMode = mode\r\n}\r\n\r\nexport const resetChanges = (state) => {\r\n state.probingSites.new = []\r\n state.probingSites.deleted = []\r\n state.probingSites.existing.forEach(probingSite => {\r\n probingSite.isActive = false\r\n })\r\n}\r\n","import {mapValues, groupBy} from 'lodash'\r\n\r\nimport * as actions from './actions'\r\nimport * as mutations from './mutations'\r\n\r\nfunction getUndeletedProbingSitesAsArray (probingSitesObject) {\r\n const filterDeleted = x => !probingSitesObject.deleted.map(x => x.id).includes(x.id)\r\n\r\n return probingSitesObject.existing.filter(filterDeleted).concat(probingSitesObject.new.filter(filterDeleted))\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n // selecting which order to plan\r\n incompleteOrders: [],\r\n selectedOrderId: null,\r\n // overall order planning\r\n probingSitesByFieldId: {}, // {[fieldId]: probingSites}\r\n selectedFieldId: null,\r\n // current field\r\n showNumbers: false,\r\n selectedZoneMapId: null,\r\n probingSiteMode: 'probingPoints',\r\n probingSites: {\r\n existing: [],\r\n new: [],\r\n deleted: []\r\n }\r\n },\r\n getters: {\r\n selectedOrder (state) {\r\n return state.incompleteOrders.find(x => x.id === state.selectedOrderId) || null\r\n },\r\n safeProbingSitesByFieldId (state, getters) {\r\n const lookup = {}\r\n\r\n const fieldIds = getters.selectedOrder ? getters.selectedOrder.selectedFieldIds : []\r\n\r\n for (const fieldId of fieldIds) {\r\n const storedProbingSites = state.probingSitesByFieldId[fieldId] || {\r\n existing: [],\r\n new: [],\r\n deleted: []\r\n }\r\n\r\n // NOTE use edit buffer instead of potentially outdated swap storage for selected field\r\n lookup[fieldId] = getUndeletedProbingSitesAsArray(fieldId === state.selectedFieldId ? state.probingSites : storedProbingSites)\r\n }\r\n return lookup\r\n },\r\n activeProbingSitesByFieldId (state, getters) {\r\n return mapValues(getters.safeProbingSitesByFieldId, probingSites => probingSites.filter(x => x.isActive))\r\n },\r\n activeCountByFieldId (state, getters) {\r\n return mapValues(getters.activeProbingSitesByFieldId, probingSites => probingSites.length)\r\n },\r\n duplicateLabelsByFieldId (state, getters) {\r\n return mapValues(getters.activeProbingSitesByFieldId, probingSites => {\r\n const grouped = groupBy(probingSites, probingSite => probingSite.label)\r\n return Object.keys(grouped).filter(label => grouped[label].length > 1)\r\n })\r\n },\r\n allFieldsPlanned (state, getters) {\r\n return Object.values(getters.activeCountByFieldId).every(x => x > 0)\r\n },\r\n duplicateLabelsFound (state, getters) {\r\n return Object.values(getters.duplicateLabelsByFieldId).some(duplicates => duplicates.length)\r\n }\r\n },\r\n actions,\r\n mutations\r\n}\r\n","import {parse} from 'wellknown'\r\nimport moment from 'moment'\r\n\r\nexport function csv (state) {\r\n if (!state.selectedOrder) {\r\n return null\r\n }\r\n\r\n const order = state.selectedOrder\r\n\r\n const header = 'NUMBER,NAME,LONGITUDE,LATITUDE'\r\n\r\n const rows = order.geometries.map(({geometry, sampleId}, i) => {\r\n const [longitude, latitude] = parse(geometry).coordinates\r\n\r\n return `${i + 1},${sampleId},${longitude},${latitude}`\r\n })\r\n\r\n const name = `${order.name.replace(/\\s/g, '_') || 'SamplingOrder'}_${moment(order.created).local().format('YYYY-MM-DD_HH-mm')}`\r\n\r\n return {name, body: [header].concat(rows).join('\\n')}\r\n}\r\n","import {smarterPost} from '@helpers/vuex/data-loading'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as getters from './getters'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n openOrders: [],\r\n selectedOrder: null,\r\n optionalSampleIdKey: null,\r\n optionalFieldNameKey: null\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'openOrders',\r\n 'selectedOrder',\r\n 'optionalSampleIdKey',\r\n 'optionalFieldNameKey'\r\n ])\r\n },\r\n actions: {\r\n downloadAsShape ({state}) {\r\n return smarterPost(`/api/v2/base-fertilization/export-order/${state.selectedOrder.id}`, null, {\r\n id: 'bf.order.export'\r\n })\r\n }\r\n },\r\n getters\r\n}\r\n","import LineString from 'ol/geom/LineString'\r\nimport proj4 from 'proj4'\r\nimport distance from '@turf/distance'\r\n\r\nconst threshold = 20\r\n\r\nexport function processProbingGeometry (feature) {\r\n const geometry = feature.getGeometry()\r\n const type = geometry.getType()\r\n\r\n if (type === 'Point') return feature\r\n\r\n if (type !== 'LineString') throw new Error(`invalid geometry type '${type}', only 'Point' and 'LineString' are supported`)\r\n\r\n const coordinates = feature.getGeometry().getCoordinates()\r\n\r\n const filledCoordinates = []\r\n\r\n coordinates.forEach((coordinate, i) => {\r\n if (i !== 0) {\r\n const previousCoordinate = coordinates[i - 1]\r\n const [x1, y1] = proj4('EPSG:3857', 'EPSG:4326', previousCoordinate)\r\n const [x2, y2] = proj4('EPSG:3857', 'EPSG:4326', coordinate)\r\n const d = distance([x1, y1], [x2, y2]) * 1000\r\n\r\n if (d > threshold) {\r\n const line = new LineString([previousCoordinate, coordinate])\r\n const num = Math.floor(d / threshold)\r\n\r\n filledCoordinates.push(...new Array(num).fill(null).map((x, i) => line.getCoordinateAt((i + 1) / (num + 1))))\r\n }\r\n }\r\n\r\n filledCoordinates.push(coordinate)\r\n })\r\n\r\n feature.getGeometry().setCoordinates(filledCoordinates)\r\n\r\n return feature\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {toWkt} from '@helpers/openlayers/features'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport {processProbingGeometry} from './process-probing-geometry'\r\n\r\nconst uploadDefaults = () => ({\r\n shapeFileFeatures: [],\r\n columnMapping: {\r\n sampleId: null\r\n }\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n upload: uploadDefaults()\r\n },\r\n getters: {\r\n allSampleIdsAreValid (state) {\r\n return state.upload.shapeFileFeatures.every(feature => feature.get(state.upload.columnMapping.sampleId))\r\n },\r\n sampleIdPropertyExists (state) {\r\n return state.upload.shapeFileFeatures.some(feature => feature.getKeys().includes(state.upload.columnMapping.sampleId))\r\n },\r\n isValid (state, getters) {\r\n return state.upload.shapeFileFeatures.length && getters.allSampleIdsAreValid && !getters.hasMultiPointGeometries\r\n },\r\n validSampleIdColumn (state, getters) {\r\n return getters.shapeFileColumns.includes(state.upload.columnMapping.sampleId)\r\n },\r\n shapeFileColumns (state) {\r\n if (!state.upload.shapeFileFeatures.length) return []\r\n\r\n return Object.keys(state.upload.shapeFileFeatures[0].getProperties())\r\n },\r\n hasMultiPointGeometries (state) {\r\n return state.upload.shapeFileFeatures.some(feature => feature.getGeometry().getType() === 'MultiPoint')\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'upload.columnMapping.sampleId',\r\n 'upload.shapeFileFeatures'\r\n ]),\r\n reset (state) {\r\n state.upload = uploadDefaults()\r\n }\r\n },\r\n actions: {\r\n importOrder ({state, rootState, dispatch, rootGetters}, {features, name}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const geometries = features.map((feature, i) => ({\r\n geometry: toWkt(processProbingGeometry(feature)),\r\n sampleId: feature.get(state.upload.columnMapping.sampleId) || i + 1,\r\n fieldName: feature.get(state.upload.columnMapping.fieldName) || ''\r\n }))\r\n\r\n const order = {\r\n selectedFieldIds: rootState.fieldRecordSystem.basicFertilization.orderCreation.order.selectedFieldIds,\r\n geometries,\r\n name\r\n }\r\n\r\n return axios.post(`/api/v2/base-fertilization/orgunits/${orgUnitId}/import-order`, order)\r\n .then(response => response.data)\r\n .then(samplingOrderId => {\r\n return dispatch('fieldRecordSystem/basicFertilization/resultImport/startManualEntry', samplingOrderId, {root: true})\r\n })\r\n }\r\n }\r\n}\r\n","export default [\r\n {\r\n id: 'lufa-nord-west',\r\n name: 'LUFA Nord-West',\r\n columnMapping: {\r\n sampleId: 'Schlag-Nr.',\r\n fieldName: 'Schlagbezeichnung',\r\n phosphorusValue: 'phosphor (P), mg/100g',\r\n phosphorusClassification: 'Gehaltsklasse phosphor',\r\n phosphorusIsOxide: false,\r\n magnesiumValue: 'Magnesium (Mg), mg/100g',\r\n magnesiumClassification: 'Gehaltsklasse Magnesium',\r\n magnesiumIsOxide: false,\r\n potassiumValue: 'Kalium (K), mg/100g',\r\n potassiumClassification: 'Gehaltsklasse Kalium',\r\n potassiumIsOxide: false,\r\n phValue: 'ph-Wert',\r\n phClassification: 'Gehaltsklasse Kalk/ph',\r\n limeRecommendation: 'Kalkbedarf (CaO)',\r\n SoilSubType: 'Bodenart: K�rnung'\r\n // SoilSubType: 'Bodenart: Körnung'\r\n }\r\n },\r\n {\r\n id: 'lufa-nrw-1',\r\n name: 'LUFA NRW 1',\r\n columnMapping: {\r\n sampleId: 'T¸ten-Nr:',\r\n fieldName: 'Schlagbezeichnung',\r\n phosphorusValue: 'P2O5',\r\n phosphorusClassification: 'Versorgung. P2O5',\r\n phosphorusIsOxide: true,\r\n magnesiumValue: 'Mg',\r\n magnesiumClassification: 'Versorgung. Mg',\r\n magnesiumIsOxide: false,\r\n potassiumValue: 'K2O',\r\n potassiumClassification: 'Versorgung. K2O',\r\n potassiumIsOxide: true,\r\n phValue: 'ph',\r\n phClassification: 'Versorgung. ph',\r\n limeRecommendation: null,\r\n SoilSubType: 'Bodenart'\r\n }\r\n },\r\n {\r\n id: 'lufa-nrw-2',\r\n name: 'LUFA NRW 2',\r\n columnMapping: {\r\n sampleId: 'T¸ten-Nr:',\r\n fieldName: 'Schlagbezeichnung',\r\n phosphorusValue: 'phosphor (P2O5) in CAL (mg/100g)',\r\n phosphorusClassification: null,\r\n phosphorusIsOxide: true,\r\n magnesiumValue: 'Magnesium (Mg) in CaCl2 (mg/100g)',\r\n magnesiumClassification: null,\r\n magnesiumIsOxide: false,\r\n potassiumValue: 'Kalium (K2O) in CAL (mg/100g)',\r\n potassiumClassification: null,\r\n potassiumIsOxide: true,\r\n phValue: 'ph-Wert in CaCl2',\r\n phClassification: null,\r\n limeRecommendation: null,\r\n SoilSubType: 'Bodenart'\r\n }\r\n },\r\n {\r\n id: 'bolap',\r\n name: 'Bolap',\r\n columnMapping: {\r\n sampleId: 'BP_NR',\r\n fieldName: 'SCHLAG',\r\n phosphorusValue: 'P',\r\n phosphorusClassification: 'PSTUFE',\r\n phosphorusIsOxide: true,\r\n magnesiumValue: 'MG',\r\n magnesiumClassification: 'MGSTUFE',\r\n magnesiumIsOxide: false,\r\n potassiumValue: 'K',\r\n potassiumClassification: 'KSTUFE',\r\n potassiumIsOxide: true,\r\n phValue: 'ph',\r\n phClassification: 'phSTUFE',\r\n limeRecommendation: null,\r\n SoilSubType: 'BODENART'\r\n }\r\n },\r\n {\r\n id: 'agrolab',\r\n name: 'Agrolab',\r\n columnMapping: {\r\n sampleId: 'BP_NR',\r\n fieldName: 'SCHLAGBEZ_',\r\n phosphorusValue: 'P_MG_100G',\r\n phosphorusClassification: 'P_VS',\r\n phosphorusIsOxide: false,\r\n magnesiumValue: 'MG_MG_100G',\r\n magnesiumClassification: 'MG_VS',\r\n magnesiumIsOxide: false,\r\n potassiumValue: 'K_MG_100G',\r\n potassiumClassification: 'K_VS',\r\n potassiumIsOxide: false,\r\n phValue: 'ph',\r\n phClassification: 'ph_VS',\r\n limeRecommendation: null,\r\n SoilSubType: 'Bodenart'\r\n }\r\n }\r\n]\r\n","import axios from 'axios'\r\nimport {uniq, mapValues} from 'lodash'\r\n\r\nimport {toObject} from '@helpers/reducers'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\nimport {parse} from 'src/js/i18n/conversion'\r\nimport {computeClassificationPKMg, computeClassificationPh, isCalculationPossible} from '@frs/components/basic-fertilization/classification-calculation'\r\nimport {calculateFromOxidform} from '@frs/components/basic-fertilization/oxidform-calculation'\r\n\r\nimport labPresets from './lab-presets'\r\n\r\nconst stringToUpperCase = (value) => {\r\n return typeof value === 'string' ? value.toUpperCase() : value\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: { // manual entry or from file(s)\r\n openOrders: [],\r\n order: null,\r\n // order:\r\n // {\r\n // id,\r\n // name,\r\n // // created,\r\n // geometries: [] // {sampleId, label, geometry, isActive},\r\n // isCompleted: false\r\n // }\r\n manual: {\r\n // page: settings\r\n selectedFieldId: null,\r\n nutrients: [],\r\n timestamp: null,\r\n probingMethod: null,\r\n // page: values\r\n selectedSamplingOrderGeometryId: null\r\n },\r\n upload: { // TODO\r\n // file upload\r\n fileContents: '',\r\n semicolonSeparated: false,\r\n // analysis\r\n error: false,\r\n // column mapping\r\n useLabPreset: true,\r\n labPresets,\r\n lab: null,\r\n nutrients: [],\r\n columnMapping: {\r\n sampleId: null,\r\n fieldName: null,\r\n phosphorusValue: null,\r\n phosphorusClassification: null,\r\n phosphorusIsOxide: false,\r\n magnesiumValue: null,\r\n magnesiumClassification: null,\r\n magnesiumIsOxide: false,\r\n potassiumValue: null,\r\n potassiumClassification: null,\r\n potassiumIsOxide: false,\r\n phValue: null,\r\n phClassification: null,\r\n limeRecommendation: null,\r\n SoilSubType: null\r\n }\r\n },\r\n results: {}, // {geometry, nutrient, measurement, contentClass, timestamp}\r\n lastCalculationSoilSubTypeLookup: {},\r\n ignoreClassification: false\r\n },\r\n getters: {\r\n newResults (state, getters) {\r\n // const {timestamp} = state.manual\r\n if (!state.order) return []\r\n\r\n return Object.keys(state.results).reduce((newResults, samplingOrderGeometryId) => {\r\n const results = {\r\n samplingOrderGeometryId,\r\n // timestamp\r\n // NOTE for testing only\r\n timestamp: state.manual.timestamp\r\n }\r\n\r\n let hasNewData\r\n\r\n for (const key in state.results[samplingOrderGeometryId]) {\r\n results[key] = state.results[samplingOrderGeometryId][key]\r\n\r\n if (getters.savedResultsLookup[samplingOrderGeometryId][key]) {\r\n results[key] = null\r\n } else if (results[key]) {\r\n hasNewData = true\r\n }\r\n }\r\n\r\n if (!hasNewData) return newResults\r\n\r\n newResults.push(results)\r\n\r\n return newResults\r\n }, [])\r\n },\r\n newResultsValidity (state, getters) {\r\n const nutrients = ['phosphorus', 'magnesium', 'potassium', 'ph', 'lime']\r\n\r\n const {timestamp} = state.manual\r\n\r\n const nutrientValues = (result, nutrient) => [result[`${nutrient}Measurement`], result[`${nutrient}ContentClass`]]\r\n const nutrientValid = (result, savedResult, nutrient) => {\r\n if (nutrient === 'lime') return result.limeRecommendation ? true : null // NOTE lime is standalone, so it is always valid\r\n\r\n const values = nutrientValues(result, nutrient)\r\n const soilSubType = result.soilSubType || savedResult.soilSubType\r\n return values.every(x => x === null) ? null : !!(soilSubType && timestamp && values.every(x => x !== null))\r\n }\r\n\r\n return getters.newResults.reduce((lookup, result) => {\r\n const savedResult = getters.savedResultsLookup[result.samplingOrderGeometryId]\r\n\r\n const validityByNutrient = nutrients.reduce((lookup, nutrient) => Object.assign(lookup, {[nutrient]: nutrientValid(result, savedResult, nutrient)}), {})\r\n\r\n return Object.assign(lookup, {[result.samplingOrderGeometryId]: validityByNutrient})\r\n }, {})\r\n },\r\n newResultsCombinedValidity (state, getters) {\r\n return mapValues(getters.newResultsValidity, validityByNutrient => !Object.values(validityByNutrient).some(x => x === false))\r\n },\r\n validNewResults (state, getters) {\r\n return getters.newResults.filter(({samplingOrderGeometryId}) => getters.newResultsCombinedValidity[samplingOrderGeometryId])\r\n },\r\n csvSeparator (state) {\r\n return state.upload.semicolonSeparated ? ';' : ','\r\n },\r\n csvLinesRaw (state) {\r\n return state.upload.fileContents\r\n ? state.upload.fileContents.split(/[\\r\\n]+/).filter(x => x)\r\n : []\r\n },\r\n csvLines (state, getters) {\r\n const processLine = line => line.split(getters.csvSeparator).map(x => x.trim())\r\n\r\n return getters.csvLinesRaw.map(processLine)\r\n },\r\n csvHeaders (state, getters) {\r\n return getters.csvLines[0]\r\n },\r\n csvData (state, getters) {\r\n return getters.csvLines.slice(1)\r\n },\r\n parsedCsvData (state, getters) {\r\n const transformRow = row => row\r\n .map((x, i) => [stringToUpperCase(getters.csvHeaders[i]), x])\r\n .reduce(toObject, {})\r\n\r\n return getters.csvData.map(transformRow)\r\n },\r\n validRows (state, getters) {\r\n const sampleIdColumn = state.upload.columnMapping.sampleId\r\n\r\n return getters.parsedCsvData.filter(row => sampleIdColumn ? row[sampleIdColumn] : true)\r\n },\r\n sampleIdsAreUnique (state, getters) {\r\n const sampleIdColumn = state.upload.columnMapping.sampleId\r\n\r\n if (!sampleIdColumn) return false\r\n\r\n const ids = {}\r\n for (const row of getters.validRows) {\r\n const sampleId = row[sampleIdColumn]\r\n\r\n if (sampleId in ids) return false\r\n\r\n ids[sampleId] = true\r\n }\r\n\r\n return true\r\n },\r\n mappingComplete (state, getters) {\r\n const columnMapping = state.upload.columnMapping\r\n\r\n const nutrientIsMapped = nutrient => nutrient !== 'lime'\r\n ? columnMapping[`${nutrient}Value`] && columnMapping[`${nutrient}Classification`]\r\n : !!columnMapping.limeRecommendation\r\n\r\n return columnMapping.sampleId && (getters.sampleIdsAreUnique || columnMapping.fieldName) &&\r\n state.manual.nutrients.every(nutrientIsMapped)\r\n },\r\n savedResultsLookup (state) {\r\n const lookup = {}\r\n\r\n if (!state.order) return lookup\r\n state.order.geometries.forEach(geometry => {\r\n lookup[geometry.id] = {...geometry.results}\r\n })\r\n\r\n return lookup\r\n },\r\n canCalculateContentClasses (state, getters) {\r\n if (!Object.keys(state.results).length) return null\r\n const results = state.results[state.manual.selectedSamplingOrderGeometryId]\r\n const savedResults = getters.savedResultsLookup[state.manual.selectedSamplingOrderGeometryId]\r\n if (results === undefined) return false\r\n const nutrients = ['phosphorus', 'potassium', 'magnesium', 'ph']\r\n return nutrients.some(x => results[`${x}Measurement`] && !savedResults[`${x}ContentClass`]) && isCalculationPossible(results.soilSubType)\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'order',\r\n 'openOrders',\r\n 'manual.timestamp',\r\n 'manual.nutrients',\r\n 'manual.selectedSamplingOrderGeometryId',\r\n 'manual.probingMethod',\r\n 'upload.fileContents',\r\n 'upload.semicolonSeparated'\r\n ]),\r\n resetManualSettings (state) {\r\n state.manual.timestamp = null\r\n state.manual.probingMethod = null\r\n },\r\n generateResultsForOrder (state) {\r\n const resultLookup = {}\r\n state.order.geometries.forEach(geometry => {\r\n resultLookup[geometry.id] = {...geometry.results}\r\n })\r\n\r\n state.manual.timestamp = null\r\n state.results = resultLookup\r\n state.manual.probingMethod = state.order.probingMethod\r\n },\r\n assignResults (state, results) {\r\n Object.assign(state.results, results)\r\n },\r\n analyzeFile () {\r\n // tries to autogenerate column mapping and nutrients, and checks for errors\r\n },\r\n updateResult (state, partialResult) {\r\n Object.assign(state.results[state.manual.selectedSamplingOrderGeometryId], partialResult)\r\n\r\n // NOTE limeRecommendation doesn't matter for content class calculation\r\n if (Object.keys(partialResult).length === 1 && partialResult.limeRecommendation) return\r\n\r\n state.lastCalculationSoilSubTypeLookup = {\r\n ...state.lastCalculationSoilSubTypeLookup,\r\n [state.manual.selectedSamplingOrderGeometryId]: null\r\n }\r\n },\r\n updateColumnMapping (state, {id, column}) {\r\n if (!(id in state.upload.columnMapping)) {\r\n throw new Error('invalid column for column mapping')\r\n }\r\n state.upload.columnMapping[id] = column\r\n },\r\n setUseLabPreset (state, value) {\r\n state.upload.useLabPreset = value\r\n if (value && state.upload.lab) {\r\n Object.assign(state.upload.columnMapping, state.upload.lab.columnMapping)\r\n }\r\n },\r\n toggleSelectedFieldId (state, id) {\r\n state.manual.selectedFieldId = state.manual.selectedFieldId === id\r\n ? null\r\n : id\r\n },\r\n setLab (state, lab) {\r\n state.upload.lab = lab\r\n let columnMapping = null\r\n if (lab) {\r\n columnMapping = mapValues(lab.columnMapping, stringToUpperCase)\r\n state.upload.lab.columnMapping = columnMapping\r\n }\r\n Object.assign(state.upload.columnMapping, columnMapping)\r\n },\r\n setIgnoreClassification (state, value) {\r\n state.ignoreClassification = value\r\n },\r\n calculateClassifications (state, {savedResultsLookup, allResults}) {\r\n const {selectedSamplingOrderGeometryId} = state.manual\r\n const results = state.results\r\n const fieldInfo = state.order.fieldInfoByGeometry\r\n\r\n const nutrients = ['phosphorus', 'potassium', 'magnesium', 'ph']\r\n\r\n const calculateContentClasses = geometryId => {\r\n const result = results[geometryId]\r\n const soilSubTypeId = result.soilSubType\r\n if (!soilSubTypeId) return\r\n\r\n nutrients.forEach(nutrient => {\r\n if (savedResultsLookup[geometryId][`${nutrient}ContentClass`]) return\r\n\r\n const measurement = result[`${nutrient}Measurement`]\r\n\r\n result[`${nutrient}ContentClass`] = nutrient === 'ph'\r\n ? computeClassificationPh({measurement, soilSubTypeId})\r\n : fieldInfo[geometryId].length\r\n ? computeClassificationPKMg({\r\n nutrient,\r\n usage: fieldInfo[geometryId][0].usage,\r\n measurement,\r\n soilSubTypeId\r\n })\r\n : null\r\n })\r\n }\r\n\r\n const geometryIds = allResults\r\n ? state.order.geometries.map(x => x.id)\r\n : [selectedSamplingOrderGeometryId]\r\n\r\n const updatedSoilSubTypes = {}\r\n\r\n for (const geometryId of geometryIds) {\r\n calculateContentClasses(geometryId)\r\n\r\n updatedSoilSubTypes[geometryId] = results[geometryId].soilSubType\r\n }\r\n\r\n state.lastCalculationSoilSubTypeLookup = {\r\n ...state.lastCalculationSoilSubTypeLookup,\r\n ...updatedSoilSubTypes\r\n }\r\n },\r\n setIsOxide (state, {nutrient, value}) {\r\n state.upload.columnMapping[`${nutrient}IsOxide`] = value\r\n }\r\n },\r\n actions: {\r\n calculateClassifications ({getters, commit}, allResults = false) {\r\n commit('calculateClassifications', {savedResultsLookup: getters.savedResultsLookup, allResults})\r\n },\r\n getOpenOrders ({commit, rootGetters}, orderId = null) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n return smarterGet('/api/v2/entities/orgunits/{orgUnitId}/base-fertilization/orders/open', {\r\n id: 'bf.probingResult.orders',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => orgUnitId\r\n },\r\n onResult (orders) {\r\n commit('setOpenOrders', orders)\r\n commit('setOrder', orderId ? orders.find(order => order.id === orderId) : null)\r\n }\r\n })\r\n },\r\n startManualEntry ({commit, dispatch}, orderId = null) {\r\n commit('fieldRecordSystem/setRightView', 'probingResultManualSettings', {root: true})\r\n\r\n return dispatch('getOpenOrders', orderId)\r\n },\r\n startImportWizard ({commit}, fileContents) {\r\n commit('setFileContents', fileContents)\r\n commit('fieldRecordSystem/setRightView', 'probingResultUpload', {root: true})\r\n },\r\n finalizeImportSettings ({rootState, state, dispatch, getters, commit}) {\r\n commit('generateResultsForOrder')\r\n\r\n const {columnMapping} = state.upload\r\n\r\n const parseMeasurement = (nutrient, measurement) => {\r\n if (!measurement) return null\r\n\r\n const value = state.upload.semicolonSeparated\r\n ? parseFloat(measurement.replace(/,/g, '.'))\r\n : parseFloat(measurement)\r\n\r\n const isOxide = columnMapping[`${nutrient}IsOxide`]\r\n return isOxide ? calculateFromOxidform(nutrient, value) : value\r\n }\r\n\r\n // NOTE ids not in order cannot be matched anyways and are irrelevant\r\n const csvIdsContainedInOrder = getters.validRows\r\n .filter(row => state.order.geometries.find(geometry => geometry.sampleId === row[columnMapping.sampleId]))\r\n .map(row => row[columnMapping.sampleId])\r\n\r\n const uniqueIdsInCsv = uniq(csvIdsContainedInOrder)\r\n\r\n const findPoint = row => {\r\n const sampleId = row[columnMapping.sampleId]\r\n const fieldName = row[columnMapping.fieldName]\r\n const sampleIdIsEnough = uniqueIdsInCsv.includes(sampleId)\r\n\r\n return state.order.geometries.find(geometry => {\r\n return geometry.sampleId === sampleId && (sampleIdIsEnough || geometry.fieldName === fieldName)\r\n })\r\n }\r\n\r\n const soilSubTypes = rootState.fieldRecordSystem.data.soilSubTypes\r\n\r\n const csvResults = getters.validRows.reduce((lookup, row) => {\r\n const geometry = findPoint(row)\r\n\r\n if (!geometry) return lookup\r\n\r\n const soilSubType = soilSubTypes.find(x => x.id === row[columnMapping.SoilSubType] || x.aliases.includes(row[columnMapping.SoilSubType]) || x.soilGroup === parse(row[columnMapping.SoilSubType], 'number'))\r\n\r\n return Object.assign(lookup, {\r\n [geometry.id]: {\r\n soilSubType: soilSubType ? soilSubType.id : null,\r\n fieldName: row[columnMapping.fieldName],\r\n limeRecommendation: state.manual.nutrients.includes('lime') ? parseMeasurement('ph', row[columnMapping['limeRecommendation']]) : null,\r\n phosphorusContentClass: state.manual.nutrients.includes('phosphorus') ? row[columnMapping.phosphorusClassification] || null : null,\r\n potassiumContentClass: state.manual.nutrients.includes('potassium') ? row[columnMapping.potassiumClassification] || null : null,\r\n magnesiumContentClass: state.manual.nutrients.includes('magnesium') ? row[columnMapping.magnesiumClassification] || null : null,\r\n phContentClass: state.manual.nutrients.includes('ph') ? row[columnMapping.phClassification] || null : null,\r\n phosphorusMeasurement: state.manual.nutrients.includes('phosphorus') ? parseMeasurement('phosphorus', row[columnMapping.phosphorusValue]) : null,\r\n potassiumMeasurement: state.manual.nutrients.includes('potassium') ? parseMeasurement('potassium', row[columnMapping.potassiumValue]) : null,\r\n magnesiumMeasurement: state.manual.nutrients.includes('magnesium') ? parseMeasurement('magnesium', row[columnMapping.magnesiumValue]) : null,\r\n phMeasurement: state.manual.nutrients.includes('ph') ? parseMeasurement('ph', row[columnMapping.phValue]) : null\r\n }\r\n })\r\n }, {})\r\n commit('assignResults', csvResults)\r\n\r\n if (state.ignoreClassification) {\r\n dispatch('calculateClassifications', true)\r\n }\r\n\r\n commit('fieldRecordSystem/setRightView', 'probingResultManualValues', {root: true})\r\n },\r\n finalizeManualSettings ({commit}) {\r\n commit('resetManualSettings')\r\n commit('generateResultsForOrder')\r\n commit('fieldRecordSystem/setRightView', 'probingResultManualValues', {root: true})\r\n },\r\n saveResults ({state, getters, commit}, forceComplete) {\r\n if (!getters.newResults.length) {\r\n console.error('[BF/resultImport] saving was attempted without results')\r\n return\r\n }\r\n\r\n const {id: orderId} = state.order\r\n\r\n const url = `/api/v2/base-fertilization/orders/${orderId}/results`\r\n const completeUrl = `/api/v2/base-fertilization/orders/${orderId}/is-completed`\r\n const data = {\r\n probingMethod: state.manual.probingMethod,\r\n results: getters.validNewResults\r\n }\r\n\r\n return axios.post(url, data)\r\n .then(response => response.data)\r\n .then(metrics => {\r\n commit('fieldRecordSystem/setRightView', 'basicFertilization', {root: true})\r\n if (forceComplete) {\r\n return axios.put(completeUrl).then(() => metrics)\r\n }\r\n return metrics\r\n })\r\n },\r\n createNutritionMap ({rootState, dispatch}, {fieldId, nutrients}) {\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n return axios.post(`/api/v2/base-fertilization/fields/${fieldId}/nutrient-maps/${harvestYear}`, nutrients)\r\n .then(() => dispatch('fieldRecordSystem/basicFertilization/loadStatistics', null, {root: true}))\r\n },\r\n createYoutrackIssue (store, formData) {\r\n return axios.post('/api/v2/base-fertilization/create-youtrack-issue', formData\r\n , {\r\n headers: {\r\n 'Content-Type': 'multipart/form-data'\r\n }\r\n })\r\n }\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n selectedFieldId: null,\r\n selectedNutrient: null,\r\n showClassifications: false,\r\n showZentroid: false\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'selectedFieldId',\r\n 'selectedNutrient',\r\n 'showClassifications',\r\n 'showZentroid'\r\n ])\r\n },\r\n actions: {\r\n startNutrientMapDisplay ({commit}) {\r\n commit('setSelectedFieldId', null)\r\n commit('fieldRecordSystem/setRightView', 'nutrientMapDisplay', {root: true})\r\n },\r\n loadNutrientMaps ({commit, dispatch, rootState}, fieldId) {\r\n return dispatch('fieldRecordSystem/mapManagement/loadNutrientMaps', fieldId, {root: true})\r\n .then(() => {\r\n const nutrientMapIds = rootState.fieldRecordSystem.mapManagement.data.nutrientMap.mapIdsByFieldId[fieldId]\r\n nutrientMapIds.forEach(mapId => {\r\n dispatch('fieldRecordSystem/mapManagement/loadNutrientMapDetails', mapId, {root: true})\r\n })\r\n })\r\n }\r\n }\r\n}\r\n","export function startApplicationMapCreation ({commit, dispatch}) {\r\n dispatch('masterData/reloadCropHarvestQualities', false, {root: true})\r\n\r\n commit('fieldRecordSystem/setRightView', 'applicationMapCreation', {root: true})\r\n dispatch('navigateToStart')\r\n}\r\n\r\nexport function navigateToStart ({commit}) {\r\n commit('setStep', 'basicSettings')\r\n commit('startCreation')\r\n}\r\n\r\nexport function startYieldPlanning ({commit}) {\r\n commit('initializeYieldPlanningData')\r\n commit('setStep', 'yieldPlanning')\r\n}\r\n\r\nexport function adjustHeterogenity ({commit}) {\r\n commit('setStep', 'heterogenityAdjustment')\r\n}\r\n","import {smarterPost} from '@helpers/vuex/data-loading'\r\nimport {toObject} from '@helpers/reducers'\r\n\r\nexport async function createApplicationMap ({state, commit, dispatch, rootState}) {\r\n await dispatch('calculateYieldDataForField')\r\n\r\n const {nutrients, zoneMapId, ...otherParameters} = state.creationParameters\r\n\r\n const selectedNutrients = Object.keys(nutrients).filter(nutrient => nutrients[nutrient].selected)\r\n\r\n const data = {\r\n ...otherParameters,\r\n minMaxValuesByNutrient: selectedNutrients.map(nutrient => [nutrient, {\r\n min: nutrients[nutrient].min,\r\n max: nutrients[nutrient].max\r\n }]).reduce(toObject, {})\r\n }\r\n\r\n // at the moment the fieldIds of zonemapIdByFieldId are used to create the maps in the backend, so there must be at least an entry for the currently selected field\r\n if (Object.keys(data.zoneMapIdByFieldId).length === 0) {\r\n data.zoneMapIdByFieldId[state.selectedFieldId] = null\r\n }\r\n\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n commit('setStep', 'basicSettings')\r\n commit('resetAfterCreation')\r\n await smarterPost(`/api/v2/base-fertilization/application-maps/${harvestYear}`, data, {\r\n id: 'bf.applicationMaps.create'\r\n })\r\n}\r\n","import {fromPairs, orderBy} from 'lodash'\r\n\r\nconst plannedYieldDefaults = () => ({\r\n cropUsageId: null,\r\n cropHarvestQualityId: null,\r\n averageYield: null,\r\n unit: 'dt/ha',\r\n useByProduct: false,\r\n zoneYields: [],\r\n zoneWithdrawals: {}\r\n})\r\n\r\nexport function initializeYieldPlanningData (state) {\r\n state.years = 1\r\n\r\n if (state.creationParameters.plannedYields.length > 0) return\r\n state.creationParameters.plannedYields = [plannedYieldDefaults()]\r\n}\r\n\r\nexport function removePlannedYields (state) {\r\n const length = state.creationParameters.plannedYields.length\r\n for (let i = length; i > state.years; i--) {\r\n state.creationParameters.plannedYields.pop()\r\n }\r\n}\r\n\r\nexport function addPlannedYields (state) {\r\n const length = state.creationParameters.plannedYields.length\r\n for (let i = length; i < state.years; i++) {\r\n state.creationParameters.plannedYields.push(plannedYieldDefaults())\r\n }\r\n}\r\n\r\nexport function setPlannedYieldData (state, {year, plannedYield}) {\r\n state.creationParameters.plannedYields.splice(year, 1, plannedYield)\r\n}\r\n\r\nexport function resetYieldPlanning (state) {\r\n state.years = null\r\n state.creationParameters.plannedYields = [plannedYieldDefaults()]\r\n}\r\n\r\nexport function calculateYieldData (state, {zoneMap, cropHarvestQualities}) {\r\n const firstLetterBig = s => s[0].toUpperCase() + s.substring(1)\r\n\r\n if (!zoneMap) {\r\n zoneMap = {zones: [{id: null, number: 1}]}\r\n }\r\n\r\n const {heterogenityFactors} = state.creationParameters\r\n\r\n const completedPlannedYields = state.creationParameters.plannedYields.map(plannedYields => {\r\n const quality = cropHarvestQualities[plannedYields.cropHarvestQualityId]\r\n const nutrients = Object.keys(state.creationParameters.nutrients)\r\n .filter(key => state.creationParameters.nutrients[key].selected && key !== 'ph')\r\n\r\n const calculateAdjustedYield = zone => (heterogenityFactors[zone.id] || 1) * plannedYields.averageYield\r\n\r\n plannedYields.zoneYields = orderBy(zoneMap.zones, x => x.number).map(calculateAdjustedYield)\r\n\r\n plannedYields.zoneWithdrawals = fromPairs(nutrients.map(nutrient => {\r\n const mainProductFactor = quality[`mainproduct${firstLetterBig(nutrient)}Removal`]\r\n const byProductFactor = plannedYields.useByProduct\r\n ? quality[`byproduct${firstLetterBig(nutrient)}Removal`]\r\n : 0\r\n\r\n const withdrawalFactor = mainProductFactor + byProductFactor\r\n\r\n return [nutrient, plannedYields.zoneYields.map(x => x * withdrawalFactor)]\r\n }))\r\n return plannedYields\r\n })\r\n\r\n state.creationParameters.plannedYields = completedPlannedYields\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport {spreadByHeterogenity} from '@helpers/map-creation'\r\n\r\nimport * as flowActions from './flow-actions'\r\nimport * as applicationMapActions from './actions'\r\nimport * as plannedYieldMutations from './planned-yield-mutations'\r\n\r\nconst creationParameterDefaults = () => ({\r\n zoneMapIdByFieldId: {},\r\n zoneMapId: null,\r\n heterogenityFactors: {}, // {[zoneId]: normalizedFactor}\r\n nutrients: {\r\n phosphorus: {min: null, max: null, selected: false},\r\n potassium: {min: null, max: null, selected: false},\r\n magnesium: {min: null, max: null, selected: false},\r\n ph: {min: null, max: null, selected: false}\r\n },\r\n // NOTE zoneYields and zoneWidthdrawals are only calculated for server call, not held in state\r\n plannedYields: [], // [{cropHarvestQualityId, averageYield, unit, useByProduct}...]\r\n desiredZones: 5\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n selectedFieldId: null,\r\n isApplicationValue: false,\r\n step: 'basicSettings', // basicSettings, yieldPlanning, heterogenityAdjustment\r\n creationParameters: creationParameterDefaults(),\r\n years: null,\r\n lastInitializedZoneMapId: null\r\n },\r\n getters: {\r\n zoneMap (state, getters, rootState) {\r\n return rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.creationParameters.zoneMapId]\r\n },\r\n mapsToCreate (state) {\r\n const nutrients = state.creationParameters.nutrients\r\n const selectedNutrients = Object.keys(nutrients).filter(nutrient => nutrients[nutrient].selected)\r\n return selectedNutrients\r\n },\r\n onlyPhSelected (state, getters) {\r\n return getters.mapsToCreate.length === 1 && getters.mapsToCreate[0] === 'ph'\r\n },\r\n phAndNutrientsSelected (state, getters) {\r\n return getters.mapsToCreate.length > 1 && getters.mapsToCreate.some(mapType => mapType === 'ph')\r\n },\r\n onlyNutrientsSelected (state, getters) {\r\n return getters.mapsToCreate.length >= 1 && getters.mapsToCreate.every(mapType => mapType !== 'ph')\r\n }\r\n },\r\n actions: {\r\n ...flowActions,\r\n ...applicationMapActions,\r\n setYears ({state, commit}, years) {\r\n const oldYears = state.years\r\n commit('setYears', years)\r\n commit(oldYears > years ? 'removePlannedYields' : 'addPlannedYields')\r\n },\r\n initializeHeterogenity ({state, rootState, commit}) {\r\n const zoneMap = rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.creationParameters.zoneMapId]\r\n\r\n if (!zoneMap || !zoneMap.zones) {\r\n commit('setLastInitializedZoneMapId', null)\r\n return\r\n }\r\n\r\n if (state.lastInitializedZoneMapId === zoneMap.id) return\r\n\r\n const factors = spreadByHeterogenity(1, zoneMap)\r\n\r\n commit('setHeterogenityFactors', factors)\r\n commit('setLastInitializedZoneMapId', zoneMap.id)\r\n },\r\n calculateYieldDataForField ({state, rootState, commit}) {\r\n const zoneMap = rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.creationParameters.zoneMapId]\r\n const cropHarvestQualities = rootState.masterData.cropHarvestQualities\r\n commit('calculateYieldData', {zoneMap, cropHarvestQualities})\r\n },\r\n saveHeterogenityFactors ({commit}, heterogenityFactors) {\r\n commit('setHeterogenityFactors', heterogenityFactors)\r\n commit('setStep', 'yieldPlanning')\r\n }\r\n },\r\n mutations: {\r\n ...plannedYieldMutations,\r\n ...makeSetters([\r\n 'step',\r\n 'years',\r\n 'selectedFieldId',\r\n 'isApplicationValue',\r\n 'creationParameters.nutrients',\r\n 'creationParameters.desiredZones',\r\n 'creationParameters.nutrientLimits',\r\n 'creationParameters.heterogenityFactors',\r\n 'lastInitializedZoneMapId'\r\n ]),\r\n setZoneMapId (state, id) {\r\n state.creationParameters.zoneMapId = id\r\n state.creationParameters.zoneMapIdByFieldId[state.selectedFieldId] = id\r\n },\r\n startCreation (state) {\r\n state.creationParameters = creationParameterDefaults()\r\n state.selectedFieldId = null\r\n state.lastInitializedZoneMapId = null\r\n state.years = null\r\n },\r\n resetAfterCreation (state) {\r\n state.creationParameters.zoneMapIdByFieldId = {}\r\n state.creationParameters.zoneMapId = null\r\n state.creationParameters.heterogenityFactors = {}\r\n // state.creationParameters.plannedYields = []\r\n state.lastInitializedZoneMapId = null\r\n }\r\n }\r\n}\r\n","import {fromPairs, mapValues} from 'lodash'\r\n\r\nconst safeDivideBy = factor => x => factor ? x / factor * 100 : 0\r\n\r\nexport function nutrientType (state) {\r\n const nutrientType = state.ui.applicationMap.nutrient\r\n return nutrientType.toLowerCase()\r\n}\r\n\r\nexport function mapType (state, getters) {\r\n const nutrientType = getters.nutrientType\r\n\r\n return nutrientType === 'ph' ? 'lime' : nutrientType\r\n}\r\n\r\nexport function selectedProduct (state, getters, rootState, rootGetters) {\r\n if (!state.ui.productId) return null\r\n\r\n const products = rootGetters['masterData/products']\r\n const product = products[state.ui.productId]\r\n\r\n return product\r\n}\r\n\r\nexport function productFactor (state, getters) {\r\n // NOTE nutrient contents in db are percent in range [0, 100]\r\n const {selectedProduct, mapType} = getters\r\n\r\n // ph is actually not a nutrient. if a ph-application map is selected in the ui, you have to distribute lime to the field in order to correct the ph-value.\r\n // nutrient === 'ph' ? 'lime' : nutrient\r\n\r\n if (!(selectedProduct && mapType)) return null\r\n const factor = selectedProduct[mapType]\r\n if (isNaN(factor)) {\r\n throw new Error(`invalid factor for ${mapType}: ${selectedProduct[mapType]}`)\r\n }\r\n\r\n return factor\r\n}\r\n\r\nexport function originalRawValues (state) {\r\n return fromPairs(state.ui.applicationMap.zones.map(zone => [zone.id, zone.value]))\r\n}\r\n\r\nexport function originalProductValues (state, getters) {\r\n const divideByProductFactor = safeDivideBy(getters.productFactor)\r\n return mapValues(getters.originalRawValues, divideByProductFactor)\r\n}\r\n\r\nexport function adjustedRawValues (state, getters) {\r\n return mapValues(getters.originalRawValues, value => {\r\n const averageAdjustment = state.ui.previousFertilization ? state.ui.previousFertilization : 0\r\n\r\n // TODO change static values with values from original preview map, after merge branches\r\n const {min, max} = state.ui.applicationMap.metaData.orderParameters.minMaxValuesByNutrient[getters.nutrientType]\r\n\r\n return Math.max(Math.min(value - averageAdjustment, max || Infinity), min || 0)\r\n })\r\n}\r\n\r\nexport function adjustedProductValues (state, getters) {\r\n const divideByProductFactor = safeDivideBy(getters.productFactor)\r\n return mapValues(state.ui.manuallyAdjustedZoneValues, divideByProductFactor)\r\n}\r\n\r\nexport function manuallyAdjustedValues (state, getters) {\r\n return state.ui.isApplicationValue\r\n ? getters.adjustedProductValues\r\n : state.ui.manuallyAdjustedZoneValues\r\n}\r\n","import {smarterGet, smarterPost} from '@helpers/vuex/data-loading'\r\n\r\nexport async function startApplicationMapPreview ({commit, rootGetters, dispatch}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationMapPreview', {root: true})\r\n commit('resetUi')\r\n commit('resetFieldId')\r\n\r\n await dispatch('loadApplicationMapsPreview')\r\n}\r\n\r\nexport async function loadApplicationMapsPreview ({commit, rootGetters}) {\r\n return smarterGet('/api/v2/base-fertilization/orgunits/{orgUnitId}/application-map-preview-infos/{harvestYear}', {\r\n id: 'orgUnit.bf.applicationMaps.preview',\r\n expiry: 60,\r\n inputs: {\r\n orgUnitId: () => rootGetters['fieldRecordSystem/orgUnitId'],\r\n harvestYear: () => rootGetters['fieldRecordSystem/harvestYear']\r\n },\r\n async onResult (maps) {\r\n commit('setApplicationMapsForPreview', maps)\r\n }\r\n })\r\n}\r\n\r\nexport function adjustZoneValueManually ({state, getters, commit}, {value, zoneId}) {\r\n const rawValue = state.ui.isApplicationValue ? value * getters.productFactor / 100 : value\r\n commit('adjustZoneValueManually', {value: rawValue, zoneId})\r\n}\r\n\r\nexport function loadApplicationMap ({state, commit, getters}, applicationMapId) {\r\n if (!applicationMapId) return\r\n const applicationMap = state.data.applicationMaps.find(map => map.id === applicationMapId)\r\n\r\n if (!applicationMap) return\r\n\r\n // geographicArea is required for FrsApplicationMapTotalSum\r\n // TODO refactor this\r\n applicationMap.zones.forEach(zone => {\r\n zone.geographicArea = zone.area\r\n })\r\n\r\n commit('setApplicationMap', applicationMap)\r\n commit('setManuallyAdjustedZoneValues', JSON.parse(JSON.stringify(getters.adjustedRawValues)))\r\n}\r\n\r\nexport function setPreviousFertilization ({commit, getters}, value) {\r\n commit('setPreviousFertilization', value)\r\n commit('setManuallyAdjustedZoneValues', JSON.parse(JSON.stringify(getters.adjustedRawValues)))\r\n}\r\n\r\nexport function deleteSelectedMap ({state, commit, dispatch}) {\r\n const applicationMap = state.ui.applicationMap\r\n if (!applicationMap) {\r\n throw Error('No map selected')\r\n }\r\n\r\n return smarterPost('/api/v2/base-fertilization/application-map-preview/{applicationMapId}/delete', null, {\r\n id: 'bf.applicationMap.preview.delete',\r\n inputs: {\r\n applicationMapId: () => applicationMap.id\r\n },\r\n onResult () {\r\n dispatch('removeSelectedMap')\r\n }\r\n })\r\n}\r\n\r\nexport function saveApplicationMap ({state, dispatch, getters}) {\r\n const applicationMap = state.ui.applicationMap\r\n if (!applicationMap) {\r\n throw Error('No map selected')\r\n }\r\n\r\n const dto = {\r\n productId: state.ui.productId,\r\n previousFertilization: state.ui.previousFertilization ? state.ui.previousFertilization : 0,\r\n zones: applicationMap.zones.map(zone => ({\r\n ...zone,\r\n value: getters.adjustedProductValues[zone.id]\r\n }))\r\n }\r\n\r\n return smarterPost('/api/v2/base-fertilization/application-map-preview/{applicationMapId}/save', dto, {\r\n id: 'bf.applicationMap.preview.save',\r\n inputs: {\r\n applicationMapId: () => applicationMap.id\r\n },\r\n onResult () {\r\n dispatch('removeSelectedMap')\r\n }\r\n })\r\n}\r\n\r\nexport function removeSelectedMap ({commit}) {\r\n commit('removeMapFromArray')\r\n commit('removeMapFromLookup')\r\n commit('resetUi')\r\n}\r\n","import {postProcessingUiParameterDefaults} from './index'\r\n\r\nexport function setApplicationMapsForPreview (state, maps) {\r\n state.data = maps\r\n}\r\n\r\nexport function adjustZoneValueManually (state, {value, zoneId}) {\r\n state.ui.manuallyAdjustedZoneValues[zoneId] = value\r\n}\r\n\r\nexport function resetFieldId (state) {\r\n state.selectedFieldId = null\r\n}\r\n\r\nexport function resetUi (state) {\r\n state.ui = postProcessingUiParameterDefaults()\r\n}\r\n\r\nexport function setPreviousFertilization (state, value) {\r\n state.ui.previousFertilization = value\r\n}\r\n\r\nexport function removeMapFromArray (state) {\r\n const applicationMapId = state.ui.applicationMap.id\r\n const index = state.data.applicationMaps.map(map => map.id).indexOf(applicationMapId)\r\n if (index >= 0) {\r\n state.data.applicationMaps.splice(index, 1)\r\n }\r\n}\r\n\r\nexport function removeMapFromLookup (state) {\r\n const applicationMapId = state.ui.applicationMap.id\r\n const mapIdsByFieldId = state.data.applicationMapIdsByFieldId\r\n const fieldIds = Object.keys(mapIdsByFieldId)\r\n\r\n fieldIds.forEach(fieldId => {\r\n const index = mapIdsByFieldId[fieldId].indexOf(applicationMapId)\r\n\r\n if (index >= 0) {\r\n mapIdsByFieldId[fieldId].splice(index, 1)\r\n }\r\n })\r\n}\r\n\r\nexport function resetInputs (state) {\r\n state.ui.productId = null\r\n state.ui.previousFertilization = null\r\n state.ui.isApplicationValue = false\r\n state.ui.applicationMap.zones.forEach(zone => {\r\n state.ui.manuallyAdjustedZoneValues[zone.id] = zone.value\r\n })\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as getters from './getters'\r\nimport * as actions from './actions'\r\nimport * as mutations from './mutations'\r\n\r\nexport const postProcessingUiParameterDefaults = () => ({\r\n productId: null,\r\n previousFertilization: null,\r\n isApplicationValue: false,\r\n applicationMap: null,\r\n manuallyAdjustedZoneValues: {}\r\n})\r\n\r\nconst postProcessingParameterDefaults = () => ({\r\n selectedFieldId: null,\r\n data: {\r\n applicationMaps: [],\r\n applicationMapIdsByFieldId: {}\r\n },\r\n ui: postProcessingUiParameterDefaults()\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: postProcessingParameterDefaults(),\r\n getters,\r\n actions,\r\n mutations: {\r\n ...makeSetters([\r\n 'selectedFieldId',\r\n 'ui.productId',\r\n 'ui.previousFertilization',\r\n 'ui.selectedApplicationMapId',\r\n 'ui.isApplicationValue',\r\n 'ui.applicationMap',\r\n 'ui.manuallyAdjustedZoneValues'\r\n ]),\r\n ...mutations\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as mutations from './mutations'\r\nimport * as actions from './actions'\r\n\r\nimport orderCreation from './order-creation'\r\nimport orderPlanning from './order-planning'\r\nimport orderExport from './order-export'\r\nimport orderImport from './order-import'\r\nimport resultImport from './result-import'\r\nimport nutrientMaps from './nutrient-maps'\r\nimport applicationMaps from './application-maps'\r\nimport applicationMapsPreview from './application-maps-preview'\r\n\r\nconst state = {\r\n data: {\r\n nutrientMaps: {},\r\n fieldStatisticsLookup: {},\r\n simplifiedGeometries: {}\r\n // sampling results\r\n // nutrient maps\r\n // application maps\r\n },\r\n applicationMapCreation: {\r\n\r\n },\r\n ui: {\r\n selectedOrder: null, // the current selected order (used for export)\r\n selectedNutrient: null,\r\n showClassifications: false,\r\n showZentroid: false,\r\n useCustomIds: false\r\n },\r\n testing: {\r\n contentClassResults: []\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n mutations: {\r\n ...makeSetters([\r\n 'ui.selectedNutrient',\r\n 'ui.showClassifications',\r\n 'ui.showZentroid',\r\n 'ui.useCustomIds',\r\n 'data.fieldStatisticsLookup',\r\n 'data.simplifiedGeometries'\r\n ]),\r\n ...mutations\r\n },\r\n actions,\r\n modules: {\r\n orderCreation,\r\n orderPlanning,\r\n orderExport,\r\n orderImport,\r\n resultImport,\r\n nutrientMaps,\r\n applicationMaps,\r\n applicationMapsPreview\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport router from '@frs/router'\r\n\r\nexport const startEditing = ({commit, dispatch}, fieldId) => {\r\n return dispatch('reset', fieldId).then(() => {\r\n commit('fieldRecordSystem/setRightView', 'basicFieldInfoForm', {root: true})\r\n })\r\n}\r\n\r\n// TODO merge editBuffer into parent module, save usageTypes in parent module, pull initialization into reset mutation\r\nexport function reset ({rootState, rootGetters, commit}, fieldId) {\r\n let field\r\n\r\n if (fieldId) {\r\n const fieldDetails = rootState.fieldRecordSystem.data.field[fieldId]\r\n const fieldName = rootGetters['fieldRecordSystem/entityNameLookup'][fieldId]\r\n\r\n field = Object.assign({}, {id: fieldId, name: fieldName}, fieldDetails)\r\n }\r\n\r\n commit('editBuffer/reset', field)\r\n}\r\n\r\nexport async function save ({state, rootState, commit, dispatch}) {\r\n const rootDispatch = (name, payload) => dispatch(name, payload, {root: true})\r\n const rootCommit = (name, payload) => commit(name, payload, {root: true})\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n\r\n const {id, name, ...fieldData} = state.editBuffer\r\n\r\n const payload = {\r\n ...fieldData,\r\n id,\r\n orgUnitId,\r\n name: name.trim()\r\n }\r\n\r\n const serverContext = rootState.fieldRecordSystem.data.field[id]\r\n ? rootState.fieldRecordSystem.data.field[id].context\r\n : {\r\n mode: 'new'\r\n }\r\n\r\n // TODO add context to payload instead of wrapping payload in context, needs serverside changes as well\r\n const clientContext = {\r\n ...serverContext,\r\n payload\r\n }\r\n\r\n const response = await axios.post(`/api/v2/frs/${harvestYear}/fields`, clientContext)\r\n const field = response.data\r\n\r\n if (!id) {\r\n await rootDispatch('fieldRecordSystem/navigation/addEntity', {entity: field, orgUnitId})\r\n } else {\r\n await rootDispatch('fieldRecordSystem/navigation/renameEntity', {entityId: field.id, name: field.name})\r\n }\r\n\r\n rootCommit('fieldRecordSystem/updateFieldData', {[field.id]: {...fieldData, entityId: field.id}})\r\n\r\n const cropRotation = rootState.fieldRecordSystem.cropRotations.company.find(cr => cr.id === fieldData.cropRotationId)\r\n rootCommit('fieldRecordSystem/assignCropRotationToField', cropRotation)\r\n\r\n rootCommit('dataLoading/invalidate', 'harvestYear.fullFieldData')\r\n\r\n return field.id\r\n}\r\n\r\nexport async function splitField ({state, rootState, commit, dispatch}, geometries) {\r\n const rootDispatch = (name, payload) => dispatch(name, payload, {root: true})\r\n\r\n const {orgUnitId, fieldId} = rootState.fieldRecordSystem.navigation.location\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const context = {\r\n ...rootState.fieldRecordSystem.data.field[fieldId].context,\r\n payload: geometries\r\n }\r\n\r\n const response = await axios.post(`/api/v2/frs/${harvestYear}/fields/${fieldId}/executeSplit`, context)\r\n const newFields = response.data\r\n\r\n await Promise.all([\r\n ...newFields.map(field => {\r\n rootDispatch('fieldRecordSystem/navigation/addEntity', {entity: field, orgUnitId})\r\n }),\r\n rootDispatch('fieldRecordSystem/navigation/removeEntity', fieldId)\r\n ])\r\n\r\n commit('dataLoading/invalidate', 'orgUnit.simplified-geometries', {root: true})\r\n\r\n router.push({name: 'orgDashboard', params: {orgUnitId}})\r\n\r\n await rootDispatch('fieldRecordSystem/map/stopEditing')\r\n}\r\n","export function setFields (state, fields) {\r\n state.data.fields = fields\r\n}\r\n\r\nexport function setEditing (state, value) {\r\n state.ui.editing = value\r\n}\r\n\r\nexport function upsertField (state, field) {\r\n const existing = state.data.fields.find(f => f.id === field.id)\r\n if (existing) {\r\n existing.name = field.name.trim()\r\n } else {\r\n state.data.fields.push(field)\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n name: '',\r\n code: '',\r\n fieldUsage: null,\r\n area: {\r\n official: 0,\r\n cultivated: 0,\r\n geometrical: 0\r\n },\r\n cropRotationId: null,\r\n waterProtectionZone: 0,\r\n natura2000: false,\r\n waterErosion: 0,\r\n windErosion: false\r\n})\r\n\r\nconst checkValidity = partialfield => {\r\n const defaultField = defaults()\r\n for (const key in partialfield) {\r\n if (!(key in defaultField)) {\r\n console.error(`[field editBuffer] set: property '${key}' does not exist in field-details defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'name',\r\n 'code',\r\n 'fieldUsage',\r\n 'cropRotationId',\r\n 'area.cultivated',\r\n 'area.official',\r\n 'waterProtectionZone',\r\n 'natura2000',\r\n 'waterErosion',\r\n 'windErosion'\r\n ]),\r\n reset (state, field) {\r\n const mappedField = {}\r\n for (const key in field) {\r\n if (key in defaults()) {\r\n mappedField[key] = field[key]\r\n }\r\n }\r\n\r\n if (mappedField) {\r\n checkValidity(mappedField)\r\n }\r\n\r\n Object.assign(state, defaults(), mappedField)\r\n }\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport * as actions from './actions'\r\nimport * as mutations from './mutations'\r\nimport editBuffer from './editBuffer'\r\n\r\nconst state = {\r\n ui: {\r\n selection: {\r\n field: null\r\n },\r\n editing: false,\r\n saving: false,\r\n selectedClimateCategory: 'temperature'\r\n },\r\n data: {\r\n fields: [], // usually for current orgunit\r\n climateCategories: {\r\n evapotranspiration: {\r\n unit: 'mm/m²'\r\n },\r\n climaticWaterBalance: {\r\n unit: 'mm/m²'\r\n },\r\n heatSummation: {\r\n unit: '°C'\r\n },\r\n temperature: {\r\n unit: '°C'\r\n },\r\n precipitation: {\r\n unit: 'mm/m²'\r\n },\r\n wind: {\r\n unit: 'm/s'\r\n },\r\n cloudCover: {\r\n unit: '%'\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations: {\r\n ...mutations,\r\n ...makeSetters([\r\n 'ui.selectedClimateCategory',\r\n 'ui.saving'\r\n ])\r\n },\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import {cloneDeep} from 'lodash'\r\n\r\nexport const startEditing = ({rootState, commit, rootGetters}, orgUnitId) => {\r\n const orgUnit = rootGetters['fieldRecordSystem/navigation/entityLookup'][orgUnitId]\r\n\r\n const orgUnitData = rootState.fieldRecordSystem.data.orgUnits.data\r\n const hasCompanyData = (orgUnitId !== null && orgUnitData[orgUnitId].companyData !== '' && orgUnitData[orgUnitId].companyData !== null)\r\n\r\n // NOTE why build a weird object from orgUnit and other things? why not hand them over separately?\r\n const company = {\r\n id: orgUnitId,\r\n orgUnitName: orgUnit.name,\r\n shouldHaveCompanyData: hasCompanyData,\r\n companyData: orgUnitData[orgUnitId].companyData\r\n }\r\n\r\n commit('setEditing', true)\r\n commit('editBuffer/reset', {company})\r\n commit('fieldRecordSystem/setRightView', 'companyData', {root: true})\r\n}\r\n\r\nexport const stopEditing = ({state, commit}) => {\r\n commit('setEditing', false)\r\n commit('editBuffer/reset', {company: null})\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n return state.editBuffer\r\n}\r\n\r\nexport async function saveCompany ({state, rootState, rootGetters, dispatch}) {\r\n const rootDispatch = (name, payload) => dispatch(name, payload, {root: true})\r\n\r\n const {orgUnitId: currentOrgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n const clonedEditBuffer = cloneDeep(state.editBuffer)\r\n\r\n const orgUnitData = rootState.fieldRecordSystem.data.orgUnits.data\r\n // TODO one of the id checks seems redundant, verify and remove\r\n const hasCompanyData = (clonedEditBuffer.id !== null && currentOrgUnitId !== null && orgUnitData[currentOrgUnitId].companyData)\r\n\r\n const orgUnitId = clonedEditBuffer.id === null\r\n ? await rootDispatch('fieldRecordSystem/createNewOrgUnit', {\r\n name: clonedEditBuffer.orgUnitName\r\n })\r\n : currentOrgUnitId\r\n\r\n const promises = []\r\n\r\n if (clonedEditBuffer.shouldHaveCompanyData) {\r\n const {companyData} = clonedEditBuffer\r\n\r\n promises.push(rootDispatch('fieldRecordSystem/saveCompanyData', {\r\n orgUnitId,\r\n companyData\r\n }))\r\n } else if (hasCompanyData) {\r\n // delete company data\r\n promises.push(rootDispatch('fieldRecordSystem/deleteMasterData'))\r\n }\r\n\r\n if (clonedEditBuffer.id) {\r\n // update orgUnit name\r\n const {name} = rootGetters['fieldRecordSystem/entityLookup'][orgUnitId]\r\n if (name !== clonedEditBuffer.orgUnitName) {\r\n promises.push(rootDispatch('fieldRecordSystem/updateOrgUnitName', {\r\n orgUnitId,\r\n name: clonedEditBuffer.orgUnitName.trim()\r\n }))\r\n }\r\n }\r\n\r\n await Promise.all(promises)\r\n await dispatch('stopEditing')\r\n\r\n return orgUnitId\r\n}\r\n","export function setCompanies (state, companies) {\r\n state.data.companies = companies\r\n}\r\n\r\nexport function setEditing (state, value) {\r\n state.ui.editing = value\r\n}\r\n\r\nexport function upsertCompany (state, company) {\r\n const existing = state.data.companies.find(f => f.id === company.id)\r\n if (existing) {\r\n existing.name = company.name.trim()\r\n } else {\r\n state.data.companies.push(company)\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n orgUnitName: null,\r\n shouldHaveCompanyData: true,\r\n companyData: {\r\n name: null,\r\n address1: null,\r\n address2: null,\r\n address3: null,\r\n isOperatedEcologically: false,\r\n isSupplementarySourceOfIncome: false,\r\n companyForm: null,\r\n legalForm: null,\r\n invekos: null,\r\n tin: null,\r\n email: null,\r\n phoneNumber: null\r\n }\r\n})\r\n\r\nconst checkValidity = partialCompany => {\r\n const defaultCompany = defaults()\r\n for (const key in partialCompany) {\r\n if (!(key in defaultCompany)) {\r\n console.error(`[company editBuffer] set: property '${key}' does not exist in company-data defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'id',\r\n 'orgUnitName',\r\n 'shouldHaveCompanyData',\r\n 'companyData',\r\n 'companyData.address1',\r\n 'companyData.address2',\r\n 'companyData.address3',\r\n 'companyData.isOperatedEcologically',\r\n 'companyData.isSupplementarySourceOfIncome',\r\n 'companyData.companyForm',\r\n 'companyData.legalForm',\r\n 'companyData.invekos',\r\n 'companyData.tin',\r\n 'companyData.name',\r\n 'companyData.email',\r\n 'companyData.phoneNumber'\r\n ]),\r\n set (state, partialCompany) {\r\n checkValidity(partialCompany)\r\n Object.assign(state, partialCompany)\r\n },\r\n reset (state, {company}) {\r\n if (company) {\r\n checkValidity(company)\r\n Object.assign(state, company)\r\n // TODO remove once calling code works as it should\r\n if (!company.companyData) {\r\n state.companyData = defaults().companyData\r\n }\r\n } else {\r\n Object.assign(state, defaults())\r\n }\r\n }\r\n }\r\n}\r\n","export function nextPaymentData (state, getters, rootState, rootGetters) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const parentLookup = rootGetters['fieldRecordSystem/navigation/parentLookup']\r\n\r\n let parentId = orgUnitId\r\n while (parentId) {\r\n const data = rootState.fieldRecordSystem.data.orgUnits.data[parentId]\r\n\r\n if (data && data.companyData) {\r\n return {orgUnitId: parentId, ...data.companyData}\r\n }\r\n\r\n parentId = parentLookup[parentId]\r\n }\r\n return null\r\n}\r\n\r\nexport function paymentDataMZK (state, getters, rootState, rootGetters) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n const data = rootState.fieldRecordSystem.data.orgUnits.data[orgUnitId]\r\n\r\n if (data && data.companyData) {\r\n return data.companyData\r\n }\r\n return null\r\n}\r\n\r\nexport function missingPaymentData (state, getters) {\r\n return getMissingCompanyData(getters.nextPaymentData)\r\n}\r\n\r\nexport function missingPaymentDataMZK (state, getters) {\r\n return getMissingCompanyData(getters.paymentDataMZK)\r\n}\r\n\r\nfunction getMissingCompanyData (paymentData) {\r\n const requiredData = [\r\n 'address1',\r\n 'address2',\r\n 'address3',\r\n 'email',\r\n 'name',\r\n 'phoneNumber'\r\n ]\r\n\r\n if (!paymentData) {\r\n return requiredData\r\n }\r\n\r\n let missingData = []\r\n\r\n const companyData = paymentData\r\n if (companyData) {\r\n for (const propName of requiredData) {\r\n if (companyData[propName] === null || companyData[propName] === '') {\r\n missingData.push(propName)\r\n }\r\n }\r\n }\r\n return missingData\r\n}\r\n","import * as actions from './actions'\r\nimport * as mutations from './mutations'\r\nimport editBuffer from './editBuffer'\r\nimport * as getters from './getters'\r\n\r\nconst state = {\r\n ui: {\r\n selection: {\r\n company: null\r\n },\r\n editing: false\r\n },\r\n data: {\r\n companies: [] // usually for current orgunit\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n getters,\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {fromPairs} from 'lodash'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaultMeasurements = () => ({\r\n nitrogen: {\r\n timestamp: null,\r\n // NOTE value is only set indirectly via the layer values, not edited manually\r\n value: null,\r\n layer30: null,\r\n layer60: null,\r\n layer90: null,\r\n note: ''\r\n },\r\n potassium: {\r\n timestamp: null,\r\n value: null\r\n },\r\n phosphorus: {\r\n probingMethod: 'CAL',\r\n timestamp: null,\r\n value: null\r\n },\r\n magnesium: {\r\n timestamp: null,\r\n value: null\r\n },\r\n humusContent: {\r\n timestamp: null,\r\n value: null\r\n },\r\n waterLevel: {\r\n timestamp: null,\r\n value: null\r\n },\r\n ph: {\r\n timestamp: null,\r\n value: null\r\n }\r\n})\r\n\r\nfunction calculateTotalNitrogenValue (state) {\r\n const nitrogenLayerValues = ['layer30', 'layer60', 'layer90'].map(x => state.measurements.nitrogen[x])\r\n\r\n // NOTE multiple `null` values add up to `0` in JavaScript, so a check is required to handle the case where every layer is `null`; in this case the total value should also be treated as `null` and not as a `0` value measurement\r\n if (nitrogenLayerValues.some(x => x !== null)) {\r\n state.measurements.nitrogen.value = nitrogenLayerValues.reduce((total, x) => total + x, 0)\r\n } else {\r\n state.measurements.nitrogen.value = null\r\n }\r\n}\r\n\r\nfunction setUniformTimestamp (state, date) {\r\n for (const nutrient in state.measurements) {\r\n state.measurements[nutrient].timestamp = date\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n measurements: defaultMeasurements(),\r\n useUniformTimestamp: false\r\n },\r\n getters: {\r\n anyNutrientHasValue (state) {\r\n return Object.values(state)\r\n .some(x => x.value !== null)\r\n },\r\n uniformTimestamp (state) {\r\n return state.useUniformTimestamp\r\n ? state.measurements.nitrogen.timestamp\r\n : null\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'measurements.humusContent',\r\n 'measurements.waterLevel',\r\n 'measurements.ph',\r\n 'measurements.nitrogen',\r\n 'measurements.nitrogen.note',\r\n 'measurements.potassium',\r\n 'measurements.phosphorus',\r\n 'measurements.phosphorus.probingMethod',\r\n 'measurements.magnesium'\r\n ]),\r\n setLayer30 (state, value) {\r\n state.measurements.nitrogen.layer30 = value\r\n calculateTotalNitrogenValue(state)\r\n },\r\n setLayer60 (state, value) {\r\n state.measurements.nitrogen.layer60 = value\r\n calculateTotalNitrogenValue(state)\r\n },\r\n setLayer90 (state, value) {\r\n state.measurements.nitrogen.layer90 = value\r\n calculateTotalNitrogenValue(state)\r\n },\r\n setUseUniformTimestamp (state, useUniformTimestamp) {\r\n state.useUniformTimestamp = useUniformTimestamp\r\n\r\n if (useUniformTimestamp) {\r\n // ensure consistent uniform timestamp, in case individual timestamps were already set\r\n // using any existing timestamp from a specific nutrient would be arbitary and hard to understand, so it is set to `null`\r\n setUniformTimestamp(state, null)\r\n }\r\n },\r\n setUniformTimestamp,\r\n reset (state, partialNutritionStatus) {\r\n // NOTE should it become possible to have not-`null` timestamps on reset, the conditional call to `setUniformTimestamp` contained in `setUseUniformTimestamp` needs to be replicated here as well to ensure consistent state\r\n Object.assign(state.measurements, defaultMeasurements())\r\n }\r\n },\r\n actions: {\r\n startEditing ({rootState, commit}) {\r\n commit('reset')\r\n commit('fieldRecordSystem/setRightView', 'nutritionStatusForm', {root: true})\r\n },\r\n stopEditing ({state, commit}) {\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n },\r\n async save ({state, rootState, commit}) {\r\n const measurementLookup = JSON.parse(JSON.stringify(state.measurements))\r\n\r\n const {orgUnitId, fieldId} = rootState.fieldRecordSystem.navigation.location\r\n const fieldData = rootState.fieldRecordSystem.data.field[fieldId]\r\n\r\n // TODO skip save for unchanged values (compare with current field nutrient values)\r\n const measurements = Object.keys(measurementLookup)\r\n .map(type => ({...measurementLookup[type], geometry: fieldData.wkt, type}))\r\n .filter(x => x.value !== null)\r\n\r\n const dto = {\r\n nitrogen: measurements.find(x => x.type === 'nitrogen'),\r\n otherNutrients: measurements.filter(x => x.type !== 'nitrogen')\r\n }\r\n\r\n await axios.put(`/api/v2/geo-measurements/${orgUnitId}/nutrients`, dto)\r\n\r\n const nutrients = Object.assign(fieldData.nutrients, fromPairs(measurements.map(x => [x.type, x])))\r\n\r\n commit('fieldRecordSystem/updateFieldData', {[fieldId]: {nutrients}}, {root: true})\r\n }\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport moment from 'moment'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n parameters: {\r\n name: null,\r\n zoneMapId: null,\r\n cultivationId: null,\r\n cropUsageId: null,\r\n productId: null,\r\n unit: null,\r\n zoneAmounts: {}\r\n },\r\n byHeterogenity: true,\r\n averageAmount: null,\r\n reverseZoneAmounts: false\r\n },\r\n getters: {\r\n zoneMap (state, getters, rootState) {\r\n if (!state.parameters.zoneMapId) return null\r\n\r\n return rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.parameters.zoneMapId]\r\n },\r\n validUnits (state, getters, rootState, rootGetters) {\r\n const cultivationId = state.parameters.cultivationId\r\n\r\n if (!cultivationId) {\r\n return []\r\n }\r\n const filter = ['MassPerArea', 'VolumePerArea']\r\n\r\n if (state.parameters.cropUsageId) {\r\n const cropUsage = rootState.masterData.cropUsages[state.parameters.cropUsageId]\r\n const crop = rootState.masterData.crops[cropUsage.cropId]\r\n const hasCropTagForSimpleApplicationMaps = crop.tags.includes('Applikationskarten:Freie Anwendungsplanung:Körner/Fläche Einheiten')\r\n if (hasCropTagForSimpleApplicationMaps) {\r\n filter.push('CornCountPerArea')\r\n }\r\n }\r\n\r\n return rootGetters['masterData/unitArray'].filter(unit => filter.includes(unit.type)).map(unit => unit.shortcut)\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'parameters.name',\r\n 'parameters.zoneMapId',\r\n 'parameters.cultivationId',\r\n 'parameters.cropUsageId',\r\n 'parameters.unit',\r\n 'parameters.zoneAmounts',\r\n 'averageAmount',\r\n 'byHeterogenity',\r\n 'reverseZoneAmounts'\r\n ]),\r\n setProductId (state, productId) {\r\n state.parameters.productId = productId\r\n },\r\n reset (state) {\r\n state.parameters.zoneMapId = null\r\n state.parameters.zoneAmounts = {}\r\n state.parameters.name = ''\r\n state.parameters.cultivationId = null\r\n state.parameters.cropUsageId = null\r\n state.parameters.unit = null\r\n state.parameters.productId = null\r\n\r\n state.byHeterogenity = true\r\n state.averageAmount = null\r\n state.reverseZoneAmounts = false\r\n }\r\n },\r\n actions: {\r\n startSimpleApplicationMaps ({commit}) {\r\n commit('reset')\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n },\r\n async addUnitsAndGetCropusageByCultivationId ({commit, getters}, cultivationId) {\r\n await smarterGet('/api/v2/org/cultivations/{cultivationId}/details', {\r\n id: 'simpleApplicationMap.cultivation.loadDetails',\r\n inputs: {\r\n cultivationId: () => cultivationId\r\n },\r\n onResult: details => {\r\n commit('setCropUsageId', details.cropUsageId)\r\n commit('setCultivationId', cultivationId)\r\n }\r\n })\r\n\r\n const unit = getters.validUnits[0]\r\n commit('setUnit', unit)\r\n },\r\n createApplicationMap ({state, rootState, rootGetters}) {\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const url = state.byHeterogenity\r\n ? `/api/v2/simple-application-maps/${orgUnitId}/${harvestYear}/heterogenity`\r\n : `/api/v2/simple-application-maps/${orgUnitId}/${harvestYear}/zones`\r\n\r\n let data = {\r\n averageAmount: state.averageAmount,\r\n reverseZoneAmounts: state.reverseZoneAmounts,\r\n ...state.parameters\r\n }\r\n const product = rootGetters['masterData/products'][data.productId]\r\n\r\n data.name = data.name\r\n ? `${moment.utc().format('YYYY-MM-DD')}_${data.name}_${product.name}`\r\n : `${moment.utc().format('YYYY-MM-DD')}_${rootGetters['fieldRecordSystem/fieldName']}_${rootGetters['fieldRecordSystem/orgUnitName']}_${product.name}`\r\n\r\n return axios.post(url, data)\r\n },\r\n viewResultPage ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationMapCreationResultSimpleApplicationMaps', {root: true})\r\n }\r\n }\r\n}\r\n","import {smarterPost} from '@helpers/vuex/data-loading'\r\nimport moment from 'moment'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport {spreadByHeterogenity} from '@helpers/map-creation'\r\nimport {waterLevels, soilQualities, usageModifiers} from 'src/js/data/maize-sowing'\r\n\r\nconst automaticSupported = productData => productData && productData.maizeMatrix &&\r\n productData.maizeMatrix.length === 9 && productData.maizeMatrix !== [0, 0, 0, 0, 0, 0, 0, 0, 0]\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n parameters: {\r\n name: '',\r\n zoneMapId: null,\r\n cultivationId: null,\r\n productId: null,\r\n unit: 'K/m²',\r\n waterLevel: null, // for looking up base sowingDensity in matrix\r\n soilQuality: null, // for looking up base sowingDensity in matrix\r\n usage: null, // results in adjustment of sowingDensity\r\n // result\r\n zoneAmounts: {}\r\n },\r\n automatic: false,\r\n ignoreLimits: false,\r\n customSowingDensity: null\r\n },\r\n getters: {\r\n zoneMap (state, getters, rootState) {\r\n const {zoneMapId} = state.parameters\r\n const {mapLookup} = rootState.fieldRecordSystem.mapManagement.data.zoneMap\r\n\r\n return zoneMapId\r\n ? mapLookup[zoneMapId]\r\n : null\r\n },\r\n product (state, getters, rootState, rootGetters) {\r\n return rootGetters['masterData/products'][state.parameters.productId]\r\n },\r\n productData (state, getters) {\r\n return getters.product\r\n },\r\n automaticSupported (state, getters) {\r\n return automaticSupported(getters.productData)\r\n },\r\n limits (state, getters) {\r\n if (getters.productData) {\r\n const {unit} = state.parameters\r\n const {minSeedRate, maxSeedRate} = getters.productData\r\n\r\n return [minSeedRate, maxSeedRate].map(x => unit === 'K/ha' ? x * 10000 : x)\r\n }\r\n },\r\n sowingDensity (state, getters) {\r\n if (state.automatic) {\r\n const {unit, waterLevel, soilQuality, usage} = state.parameters\r\n\r\n if (!waterLevel || !soilQuality || !usage) return null\r\n\r\n const i = waterLevels.indexOf(waterLevel)\r\n const j = soilQualities.indexOf(soilQuality) * 3\r\n\r\n const averageValue = getters.productData.maizeMatrix[i + j]\r\n\r\n const factor = unit === 'K/ha' ? 10000 : 1\r\n\r\n return factor * (averageValue + usageModifiers[usage])\r\n } else {\r\n return state.customSowingDensity\r\n }\r\n },\r\n calculatedZoneAmounts (state, getters) {\r\n const amounts = spreadByHeterogenity(getters.sowingDensity, getters.zoneMap)\r\n\r\n if (!state.ignoreLimits) {\r\n const clamp = x => Math.max(getters.limits[0], Math.min(getters.limits[1], x))\r\n\r\n for (const key in amounts) {\r\n amounts[key] = clamp(amounts[key])\r\n }\r\n }\r\n\r\n return amounts\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'parameters.name',\r\n 'parameters.cultivationId',\r\n 'parameters.zoneMapId',\r\n 'parameters.unit',\r\n 'parameters.waterLevel',\r\n 'parameters.soilQuality',\r\n 'parameters.usage',\r\n 'parameters.zoneAmounts',\r\n 'parameters.productId',\r\n 'automatic',\r\n 'ignoreLimits',\r\n 'customSowingDensity'\r\n ]),\r\n reset (state) {\r\n state.parameters.zoneMapId = null\r\n state.parameters.zoneAmounts = {}\r\n state.parameters.name = ''\r\n state.parameters.cultivationId = null\r\n state.parameters.productId = null\r\n state.parameters.unit = 'K/m²'\r\n state.parameters.waterLevel = null\r\n state.parameters.soilQuality = null\r\n state.parameters.usage = null\r\n state.automatic = false\r\n state.ignoreLimits = false\r\n state.customSowingDensity = null\r\n }\r\n },\r\n actions: {\r\n startMaizeSowing ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'maizeSowing', {root: true})\r\n commit('reset')\r\n },\r\n async createApplicationMap ({state, getters, rootState, rootGetters}) {\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n // in order to satisfy the model binder on the server we need a soilType which is hardcoded\r\n // since we use the soilQuality with the corresponding matrix\r\n // the soilType is no longer used however gets stored in the metadata json with the application map\r\n\r\n let data = {\r\n ...state.parameters,\r\n automatic: state.automatic,\r\n ignoreLimits: state.ignoreLimits,\r\n customSowingDensity: state.customSowingDensity,\r\n heterogenity: getters.zoneMap.heterogenity,\r\n soilType: 'medium'\r\n }\r\n const product = rootGetters['masterData/products'][data.productId]\r\n\r\n data.name = data.name\r\n ? `${moment.utc().format('YYYY-MM-DD')}_${data.name}_${product.name}`\r\n : `${moment.utc().format('YYYY-MM-DD')}_${rootGetters['fieldRecordSystem/fieldName']}_${rootGetters['fieldRecordSystem/orgUnitName']}_${product.name}`\r\n\r\n return smarterPost(`/api/v2/maize-sowing-application-maps/${orgUnitId}/${harvestYear}`, data, {\r\n id: 'save-maize-sowing-map'\r\n })\r\n },\r\n viewResultPage ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationMapCreationResultMaizeSowing', {root: true})\r\n }\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nexport function reset ({rootState, commit}, fieldId) {\r\n const soil = rootState.fieldRecordSystem.data.field[fieldId].soil\r\n\r\n const soilDetail = {\r\n id: fieldId,\r\n soil: {\r\n soilQuality: soil.soilQuality,\r\n soilSubType: soil.soilSubType,\r\n soilType: soil.soilType,\r\n usableFieldCapacity: soil.usableFieldCapacity\r\n }\r\n }\r\n\r\n commit('editBuffer/reset', {soilDetail})\r\n}\r\n\r\nexport async function saveSoilData ({state, dispatch, commit, rootState}) {\r\n const rootCommit = (name, payload) => commit(name, payload, {root: true})\r\n\r\n const {fieldId} = rootState.fieldRecordSystem.navigation.location\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const oldSoil = rootState.fieldRecordSystem.data.field[fieldId].soil\r\n\r\n const soil = Object.assign({}, state.editBuffer.soil)\r\n commit('fieldRecordSystem/updateFieldData', {[fieldId]: {soil}}, {root: true})\r\n\r\n soil.id = fieldId\r\n const serverContext = rootState.fieldRecordSystem.data.field[fieldId].context\r\n\r\n const context = {\r\n ...serverContext,\r\n payload: soil\r\n }\r\n\r\n try {\r\n await axios.put(`/api/v2/frs/${harvestYear}/fields/${fieldId}/data/soil`, context)\r\n\r\n rootCommit('dataLoading/invalidate', 'harvestYear.fullFieldData')\r\n } catch (error) {\r\n rootCommit('fieldRecordSystem/updateFieldData', {[fieldId]: {soil: oldSoil}})\r\n throw error\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nconst defaults = () => ({\r\n id: null,\r\n soil: {\r\n soilQuality: 0,\r\n soilType: null,\r\n soilSubType: null,\r\n usableFieldCapacity: 0\r\n }\r\n})\r\n\r\nconst checkValidity = partialSoilDetail => {\r\n const defaultSoilDetail = defaults()\r\n for (const key in partialSoilDetail) {\r\n if (!(key in defaultSoilDetail)) {\r\n console.error(`[SoilDetail editBuffer] set: property '${key}' does not exist in SoilDetail defaults`)\r\n }\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state: defaults(),\r\n mutations: {\r\n ...makeSetters([\r\n 'id',\r\n 'soil'\r\n ]),\r\n setSoilQuality (state, value) {\r\n state.soil.soilQuality = value\r\n },\r\n setSoilType (state, value) {\r\n state.soil.soilType = value\r\n },\r\n setSoilSubType (state, value) {\r\n state.soil.soilSubType = value\r\n },\r\n setUsableFieldCapacity (state, value) {\r\n state.soil.usableFieldCapacity = value\r\n },\r\n set (state, partialSoilDetail) {\r\n checkValidity(partialSoilDetail)\r\n Object.assign(state, partialSoilDetail)\r\n },\r\n reset (state, {soilDetail}) {\r\n if (soilDetail) {\r\n checkValidity(soilDetail)\r\n Object.assign(state, soilDetail)\r\n } else {\r\n Object.assign(state, defaults())\r\n }\r\n }\r\n }\r\n}\r\n","import * as actions from './actions'\r\nimport editBuffer from './editBuffer'\r\n\r\nconst state = {\r\n\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n modules: {\r\n editBuffer\r\n }\r\n}\r\n","import {map} from '@helpers/objects'\r\n\r\n// columnMapping {fieldName: String, orgName: String, subOrgName: String}\r\nexport default function (geojson, columnMapping) {\r\n const tree = []\r\n const root = {children: tree}\r\n\r\n const newOrg = (name, parentName) => ({\r\n id: `${parentName}>>>>>>${name}`,\r\n type: 'org',\r\n name,\r\n children: []\r\n })\r\n\r\n const newField = (name, feature, index) => ({\r\n id: index,\r\n type: 'field',\r\n name: name || `F${index + 1}`,\r\n feature\r\n })\r\n\r\n const getOrCreateOrg = (name, parentName) => {\r\n if (!name) return null\r\n\r\n const parent = parentName ? getOrCreateOrg(parentName) : root\r\n const existing = parent.children.find(x => x.name === name && x.type === 'org')\r\n\r\n if (existing) return existing\r\n\r\n const entity = newOrg(name, parentName)\r\n parent.children.push(entity)\r\n\r\n return entity\r\n }\r\n\r\n geojson.features.forEach((feature, i) => {\r\n const {fieldName, orgName, subOrgName} = map(columnMapping, column => column && feature.properties\r\n ? feature.properties[column] || null\r\n : null)\r\n\r\n const parent = subOrgName && orgName\r\n ? getOrCreateOrg(subOrgName, orgName)\r\n : orgName || subOrgName\r\n ? getOrCreateOrg(orgName || subOrgName)\r\n : root\r\n\r\n parent.children.push(newField(fieldName, feature, i))\r\n })\r\n\r\n return tree\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport {simplifyHighQuality} from '@helpers/geojson/simplification'\r\nimport {filters, flattenEntityForest} from '@helpers/tree'\r\nimport {stringify} from 'wellknown'\r\nimport epsgCodes from 'src/js/data/epsg-codes'\r\n\r\nimport convertToTree from './convert-to-tree'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n geojson: null,\r\n columnMapping: {\r\n fieldName: null,\r\n orgName: null,\r\n subOrgName: null,\r\n colorProperty: null\r\n },\r\n selectedIds: [],\r\n showImportSimplificationHint: false\r\n },\r\n getters: {\r\n columns (state) {\r\n if (!state.geojson) return []\r\n\r\n const keys = new Set()\r\n\r\n state.geojson.features.filter(x => x.properties).forEach(feature => {\r\n Object.keys(feature.properties).forEach(key => {\r\n keys.add(key)\r\n })\r\n })\r\n\r\n return [...keys]\r\n },\r\n tree (state) {\r\n if (!state.geojson) return []\r\n\r\n return convertToTree(state.geojson, state.columnMapping)\r\n },\r\n selectedTree (state, getters) {\r\n const prune = nodes => nodes.filter(node => state.selectedIds.includes(node.id)).map(({children, ...node}) => {\r\n const clone = {\r\n ...node\r\n }\r\n if (children) {\r\n clone.children = prune(children)\r\n }\r\n return clone\r\n })\r\n\r\n return prune(getters.tree)\r\n },\r\n entityImportTree (state, getters) {\r\n const convertNode = ({type, name, feature, children}) => {\r\n const node = {\r\n content: {\r\n template: type === 'field' ? 'Parcel' : 'OrgUnit',\r\n name: name,\r\n wkt: null,\r\n children: null\r\n }\r\n }\r\n\r\n if (feature) {\r\n node.content.wkt = stringify(feature)\r\n }\r\n if (children) {\r\n node.children = children.map(convertNode)\r\n }\r\n return node\r\n }\r\n\r\n return getters.selectedTree.map(convertNode)\r\n },\r\n nodes (state, getters) {\r\n return flattenEntityForest(getters.tree)\r\n },\r\n fields (state, getters) {\r\n return getters.nodes.filter(filters.fields)\r\n },\r\n parents (state, getters) {\r\n const lookup = {}\r\n for (const node of getters.nodes) {\r\n if (node.children) {\r\n for (const child of node.children) {\r\n lookup[child.id] = node\r\n }\r\n }\r\n }\r\n return lookup\r\n },\r\n epsgCodes (state) {\r\n return epsgCodes.map(x => x.code).concat(state.customEpsgCodes)\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'geojson',\r\n 'colorProperty',\r\n 'showImportSimplificationHint'\r\n ]),\r\n reset (state) {\r\n Object.keys(state.columnMapping).forEach(key => {\r\n state.columnMapping[key] = null\r\n })\r\n state.selectedIds = []\r\n },\r\n simplifyAndSetGeojson (state, geojson) {\r\n geojson.features.forEach(feature => {\r\n simplifyHighQuality(feature.geometry)\r\n })\r\n\r\n state.geojson = geojson\r\n },\r\n addCustomEpsgCode (state, code) {\r\n if (!state.customEpsgCodes.includes(code)) {\r\n state.customEpsgCodes.push(code)\r\n }\r\n },\r\n updateColumnMapping (state, {id, column}) {\r\n if (!(id in state.columnMapping)) {\r\n throw new Error('invalid column for column mapping')\r\n }\r\n state.columnMapping[id] = column\r\n },\r\n toggleNode (state, {node, parents}) {\r\n const selected = !state.selectedIds.includes(node.id)\r\n\r\n const selectedIds = new Set(state.selectedIds)\r\n\r\n const toggleSingleNode = node => {\r\n if (selected) {\r\n selectedIds.add(node.id)\r\n } else {\r\n selectedIds.delete(node.id)\r\n }\r\n }\r\n\r\n const toggle = node => {\r\n toggleSingleNode(node)\r\n if (node.children) {\r\n node.children.forEach(toggle)\r\n }\r\n // trace selection upwards\r\n if (selected) {\r\n let parent = parents[node.id]\r\n while (parent) {\r\n toggleSingleNode(parent)\r\n parent = parents[parent.id]\r\n }\r\n }\r\n }\r\n toggle(node)\r\n\r\n state.selectedIds = [...selectedIds]\r\n }\r\n },\r\n actions: {\r\n toggleNode ({commit, getters}, node) {\r\n commit('toggleNode', {node, parents: getters.parents})\r\n },\r\n startImportPreview ({commit}, geojson) {\r\n commit('reset')\r\n commit('simplifyAndSetGeojson', geojson)\r\n commit('setShowImportSimplificationHint', true)\r\n commit('fieldRecordSystem/setRightView', 'entityImportPreview', {root: true})\r\n },\r\n cancel ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n },\r\n startImport ({rootState, getters, commit, dispatch, rootGetters}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n\r\n return axios.post(`/api/v2/entities/orgunits/${orgUnitId}/children/${harvestYear}`, getters.entityImportTree)\r\n .then(() => {\r\n commit('dataLoading/invalidate', 'orgUnit.geometries', {root: true})\r\n commit('dataLoading/invalidate', 'orgUnit.simplified-geometries', {root: true})\r\n })\r\n .then(() => dispatch('fieldRecordSystem/reloadEntities', null, {root: true}))\r\n .then(() => dispatch('fieldRecordSystem/loadFieldGeometriesForCurrentOrgUnit', null, {root: true}))\r\n .then(() => {\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n })\r\n }\r\n }\r\n}\r\n","import {smarterGet, smarterPost} from '@helpers/vuex/data-loading'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n defaultYields: [],\r\n cropUsageId: null,\r\n yield: null\r\n },\r\n getters: {\r\n selectedEntityId (state, getters, rootState, rootGetters) {\r\n return rootGetters['fieldRecordSystem/fieldId'] || rootGetters['fieldRecordSystem/orgUnitId']\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'cropUsageId',\r\n 'yield'\r\n ]),\r\n reset (state, defaultYields) {\r\n state.defaultYields = defaultYields\r\n\r\n state.yield = null\r\n state.cropUsageId = null\r\n },\r\n add (state) {\r\n state.defaultYields.push({\r\n yield: state.yield,\r\n cropUsageId: state.cropUsageId\r\n })\r\n\r\n state.yield = null\r\n state.cropUsageId = null\r\n },\r\n remove (state, cropUsageId) {\r\n const index = state.defaultYields.findIndex(x => x.cropUsageId === cropUsageId)\r\n\r\n if (index !== -1) {\r\n state.defaultYields.splice(index, 1)\r\n }\r\n }\r\n },\r\n actions: {\r\n startEditingDefaultYields ({commit, dispatch}) {\r\n dispatch('loadDefaultYields')\r\n .then(() => {\r\n commit('fieldRecordSystem/setRightView', 'defaultYields', {root: true})\r\n })\r\n },\r\n loadDefaultYields ({commit, getters, rootState}) {\r\n return smarterGet('/api/v2/entities/{fieldId}/default-yields/{harvestYear}', {\r\n id: 'defaultYields.editing.load',\r\n expiry: 0,\r\n inputs: {\r\n fieldId: () => getters.selectedEntityId,\r\n harvestYear: () => rootState.fieldRecordSystem.userSettings.harvestYear\r\n },\r\n onResult (defaultYields) {\r\n commit('reset', defaultYields)\r\n }\r\n })\r\n },\r\n save ({state, commit, getters, rootState}) {\r\n const entityId = getters.selectedEntityId\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n return smarterPost(`/api/v2/entities/${entityId}/default-yields/${harvestYear}`, state.defaultYields, {\r\n id: 'defaultYields.editing.save',\r\n expiry: 0\r\n })\r\n .then(() => {\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n })\r\n }\r\n }\r\n}\r\n","import {pick} from 'lodash'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport {smarterGet, smarterPost} from '@helpers/vuex/data-loading'\r\n\r\nimport {makeTemplate, commonParameters, validUnits, convertApplicationValues} from './algorithm-definitions'\r\nimport moment from 'moment'\r\n\r\nconst applicationMapsDataDefaults = () => ({\r\n applicationMapCalculated: false,\r\n applicationMapCreationFailed: false,\r\n applicationMapId: null\r\n})\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n parameters: null,\r\n ui: {\r\n page: 'parameters', // 'parameters' or 'preview'\r\n algorithmCollection: null\r\n },\r\n // old post-creation page stuff\r\n data: applicationMapsDataDefaults()\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'ui.algorithmCollection',\r\n 'parameters.name',\r\n 'parameters.productId',\r\n 'parameters.unit',\r\n 'parameters.applicationValues',\r\n 'parameters.zoneMapId',\r\n 'parameters.cultivationId',\r\n // algorithm-specific mutations\r\n // underroot fertilization\r\n 'parameters.temperature',\r\n // winter wheat\r\n 'parameters.type',\r\n 'parameters.dateOfSeed',\r\n 'parameters.thousandKernelWeight',\r\n 'parameters.germinationCapacity',\r\n 'parameters.germination',\r\n 'parameters.additionalZoneValues',\r\n // maize\r\n 'parameters.estimatedPrecipitation',\r\n 'parameters.minSoilMoisture',\r\n 'parameters.maxSoilMoisture'\r\n ]),\r\n startCreation (state) {\r\n state.parameters = commonParameters()\r\n state.ui.page = 'parameters'\r\n state.ui.algorithmCollection = null\r\n },\r\n setAlgorithm (state, algorithmObject) {\r\n const units = validUnits[algorithmObject.algorithmGroup]\r\n const cleanedParameters = pick(state.parameters, Object.keys(commonParameters()))\r\n\r\n const algorithmTemplate = makeTemplate(algorithmObject.algorithmGroup)\r\n if (units.find(x => x === cleanedParameters.unit)) {\r\n delete algorithmTemplate.unit\r\n }\r\n\r\n state.parameters = Object.assign(cleanedParameters, algorithmTemplate, {algorithm: algorithmObject.name})\r\n },\r\n showPreview (state, {applicationValues, algorithmOutput, algorithmParameters}) {\r\n const {unit} = state.parameters\r\n state.parameters.applicationValues = convertApplicationValues({applicationValues, unit})\r\n\r\n // algorithmOutput and algorithmParameters are used for the metadata object in the database\r\n // when saving the application map\r\n state.parameters.algorithmOutput = algorithmOutput\r\n state.parameters.algorithmParameters = algorithmParameters\r\n state.ui.page = 'preview'\r\n },\r\n discardPreview (state) {\r\n state.parameters.applicationValues = null\r\n state.parameters.algorithmOutput = null\r\n state.parameters.algorithmParameters = null\r\n state.ui.page = 'parameters'\r\n },\r\n // old post-creation page stuff\r\n setApplicationMapCalculated (state, {ready, failed}) {\r\n state.data.applicationMapCalculated = ready\r\n state.data.applicationMapCreationFailed = failed\r\n },\r\n resetCreationStatus (state) {\r\n state.data.applicationMapCalculated = false\r\n state.data.applicationMapCreationFailed = false\r\n },\r\n setApplicationMapId (state, id) {\r\n state.data.applicationMapId = id\r\n },\r\n reset (state) {\r\n Object.assign(state.data, applicationMapsDataDefaults())\r\n }\r\n },\r\n actions: {\r\n async startCreation ({commit, dispatch}) {\r\n await dispatch('i18n/preloadTranslations', ['applicationMaps'], {root: true})\r\n\r\n commit('startCreation')\r\n commit('fieldRecordSystem/setRightView', 'algorithmicApplicationMapCreation', {root: true})\r\n },\r\n loadAdditionalZoneValues ({state, rootState, commit}) {\r\n if (!state.parameters.zoneMapId || state.parameters.additionalZoneValues === undefined) return\r\n\r\n const algorithm = rootState.masterData.productAlgorithms[state.parameters.algorithm]\r\n\r\n return smarterGet('/api/v2/zone-maps/{zoneMapId}/additional-values', {\r\n id: 'frs.applicationMaps.additionalZoneValues.load',\r\n sharedCache: true,\r\n expiry: 0,\r\n inputs: {\r\n zoneMapId: () => state.parameters.zoneMapId\r\n },\r\n onResult (data) {\r\n if (!['wimexWinterWheat', 'wimexMaize'].includes(algorithm.algorithmGroup)) return\r\n\r\n const values = {}\r\n\r\n data.zoneValues.forEach(zoneData => {\r\n values[zoneData.zoneId] = {}\r\n\r\n for (const key of ['waterAvailability', 'acreRatio', 'pwc']) {\r\n if (algorithm.algorithmGroup !== 'wimexWinterWheat' && key === 'waterAvailability') continue\r\n\r\n values[zoneData.zoneId][key] = zoneData[key]\r\n }\r\n })\r\n\r\n commit('setAdditionalZoneValues', values)\r\n }\r\n })\r\n },\r\n runAlgorithm ({state, commit, rootState}) {\r\n const zoneMap = rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.parameters.zoneMapId]\r\n\r\n const dto = {\r\n algorithm: state.parameters.algorithm\r\n }\r\n\r\n if (state.parameters.algorithm.startsWith('SeedExpert_WinterWheat')) {\r\n dto.parameters = {\r\n dateOfSeed: state.parameters.dateOfSeed,\r\n type: state.parameters.type,\r\n thousandKernelWeight: state.parameters.thousandKernelWeight,\r\n germination: state.parameters.germination,\r\n germinationCapacity: state.parameters.germinationCapacity,\r\n zones: zoneMap.zones.map(zone => ({\r\n zoneId: zone.number,\r\n pwc: state.parameters.additionalZoneValues[zone.id].pwc,\r\n acresRatio: state.parameters.additionalZoneValues[zone.id].acreRatio, // NOTE name discrepancy on backend\r\n waterAvailability: state.parameters.additionalZoneValues[zone.id].waterAvailability\r\n }))\r\n }\r\n }\r\n if (state.parameters.algorithm.startsWith('SeedExpert_Corn') || state.parameters.algorithm.startsWith('SeedExpert_EnergyPlantCorn')) {\r\n dto.parameters = {\r\n estimatedPrecipitation: state.parameters.estimatedPrecipitation,\r\n minSoilMoisture: state.parameters.minSoilMoisture,\r\n maxSoilMoisture: state.parameters.maxSoilMoisture,\r\n zones: zoneMap.zones.map(zone => ({\r\n zoneId: zone.number,\r\n pwc: state.parameters.additionalZoneValues[zone.id].pwc,\r\n acresRatio: state.parameters.additionalZoneValues[zone.id].acreRatio // NOTE name discrepancy on backend\r\n }))\r\n }\r\n }\r\n if (state.parameters.algorithm.startsWith('FertAssist_UndergroundFertilization')) {\r\n dto.parameters = {\r\n currentTemperature: state.parameters.temperature,\r\n zones: zoneMap.zones.map(zone => ({zoneId: zone.number}))\r\n }\r\n }\r\n\r\n return smarterPost('/api/v2/algorithm', dto, {\r\n id: 'frs.applicationMaps.calculate'\r\n })\r\n .then(result => {\r\n const objectReducer = (byNumber) => (lookup, zone) => {\r\n lookup[zone.id] = byNumber[zone.number]\r\n return lookup\r\n }\r\n const applicationValues = zoneMap.zones.reduce(objectReducer(result.output), {})\r\n commit('showPreview', {\r\n applicationValues,\r\n algorithmOutput: result.output,\r\n algorithmParameters: result.parameters\r\n })\r\n })\r\n },\r\n async createApplicationMap ({state, rootState, rootGetters}) {\r\n // const zoneMap = rootState.fieldRecordSystem.mapManagement.data.zoneMap.mapLookup[state.parameters.zoneMapId]\r\n const {orgUnitId} = rootState.fieldRecordSystem.navigation.location\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n const url = state.parameters.algorithm.startsWith('FertAssist_UndergroundFertilization')\r\n ? `/api/v2/fert-assist/${orgUnitId}/${harvestYear}`\r\n : `/api/v2/seed-expert/${orgUnitId}/${harvestYear}`\r\n\r\n let {\r\n applicationValues: zoneAmounts,\r\n ...rest\r\n } = state.parameters\r\n\r\n const product = rootGetters['masterData/products'][rest.productId]\r\n\r\n rest.name = rest.name\r\n ? `${moment.utc().format('YYYY-MM-DD')}_${rest.name}_${product.name}`\r\n : `${moment.utc().format('YYYY-MM-DD')}_${rootGetters['fieldRecordSystem/fieldName']}_${rootGetters['fieldRecordSystem/orgUnitName']}_${product.name}`\r\n\r\n return smarterPost(url, {zoneAmounts, ...rest}, {\r\n id: 'frs.applicationMaps.save'\r\n })\r\n },\r\n cancelCreation ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'default', {root: true})\r\n },\r\n // old post-creation page stuff\r\n async createApplicationMapSuccess ({state, dispatch, commit, rootGetters}, applicationMapId) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const previewsApplicationMapId = state.data.applicationMapId\r\n try {\r\n commit('dataLoading/invalidate', 'applicationMapInfos.forField', {root: true})\r\n await dispatch('fieldRecordSystem/mapManagement/loadAvailableApplicationMapsForField', fieldId, {root: true})\r\n await dispatch('fieldRecordSystem/mapManagement/loadApplicationMapDetails', applicationMapId, {root: true})\r\n commit('setApplicationMapId', applicationMapId)\r\n commit('setApplicationMapCalculated', {ready: true, failed: false})\r\n } catch (e) {\r\n commit('setApplicationMapId', previewsApplicationMapId)\r\n commit('setApplicationMapCalculated', {ready: true, failed: true})\r\n throw e\r\n }\r\n },\r\n viewResultPage ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationMapCreationResult', {root: true})\r\n }\r\n }\r\n}\r\n","export default (type, compatPayload, fieldIdsByMapId) => {\r\n const {\r\n selectedConverter,\r\n selectedUnit,\r\n fileName,\r\n description,\r\n maps,\r\n includeFieldBorder,\r\n multipleFiles,\r\n multipleMapTypesWithMaizeSowing,\r\n harvestYear\r\n } = compatPayload\r\n\r\n // clone the lookup to avoid refs; add empty uid only for download\r\n const fieldIdsByMapIdClone = JSON.parse(JSON.stringify(fieldIdsByMapId))\r\n const geodata = maps.reduce((lookup, map) => {\r\n // maps without fields are downloaded with an empty uid.\r\n if (!(map.id in fieldIdsByMapIdClone)) {\r\n fieldIdsByMapIdClone[map.id] = ['00000000-0000-0000-0000-000000000000']\r\n }\r\n for (const fieldId of fieldIdsByMapIdClone[map.id]) {\r\n if (Object.values(lookup).find(x => Object.keys(x).includes(map.id))) continue\r\n if (!lookup[fieldId]) {\r\n lookup[fieldId] = {}\r\n }\r\n lookup[fieldId][map.id] = map.name\r\n }\r\n return lookup\r\n }, {})\r\n\r\n return {\r\n converter: selectedConverter,\r\n selectedUnitShortcut: selectedUnit,\r\n multipleMapTypesWithMaizeSowing,\r\n geodata,\r\n fileName,\r\n description,\r\n includeFieldBorder,\r\n multipleFiles,\r\n harvestYear\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {mapToColors} from '@helpers/map-color-schemes'\r\nimport {toHexAbgr} from '@helpers/color'\r\n\r\nexport async function getKmlColors (maps, mapType, applicationMapPalette, zoneMapPalette) {\r\n const colorPaletteByMap = {}\r\n\r\n const requests = await maps.map(async map => {\r\n let palette, zoneDetailsUrl\r\n\r\n if (mapType === 'zoneMap') {\r\n palette = map.category === 'BiomassMap'\r\n ? 'pastel'\r\n : zoneMapPalette\r\n zoneDetailsUrl = `/api/v2/zone-maps/${map.id}/geometry`\r\n } else if (mapType === 'applicationMap') {\r\n palette = applicationMapPalette\r\n zoneDetailsUrl = `/api/v2/application-map/${map.id}`\r\n }\r\n\r\n if (!map.zones) {\r\n const {data: {zones}} = await axios.get(zoneDetailsUrl)\r\n map.zones = zones\r\n }\r\n\r\n let colors = mapToColors(map, palette)\r\n colors = colors.map(color => toHexAbgr(color))\r\n colorPaletteByMap[map.id] = colors\r\n })\r\n return Promise.all(requests).then(() => colorPaletteByMap)\r\n}\r\n","export const convertersByMapType = {\r\n zoneMap: [\r\n 'FmxConverter',\r\n 'TmxConverter',\r\n 'ShapeConverter',\r\n 'TrimbleAgGPSConverter',\r\n 'AgroSenseSmartConverter',\r\n 'KmlConverter',\r\n 'KmzConverter'\r\n ],\r\n biomassMap: [\r\n 'FmxConverter',\r\n 'TmxConverter',\r\n 'ShapeConverter',\r\n 'TrimbleAgGPSConverter',\r\n 'AgroSenseSmartConverter',\r\n 'KmlConverter',\r\n 'KmzConverter'\r\n ],\r\n applicationMap: [\r\n 'ApplicationMapShapeConverter',\r\n 'FmxConverter',\r\n 'TmxConverter',\r\n 'TrimbleAgGPSConverter',\r\n 'IsoxmlConverter',\r\n 'AgroSenseSmartConverter',\r\n 'IsoxmlAdvancedConverter',\r\n 'ISOxmlTopconConverter',\r\n 'ShapeTopconConverter',\r\n 'IsoXmlIntellview4Converter',\r\n 'JohnDeereConverter',\r\n 'KmlConverter',\r\n 'KmzConverter'\r\n ],\r\n nutrientMap: [\r\n 'FmxConverter',\r\n 'TmxConverter',\r\n 'TrimbleAgGPSConverter',\r\n 'AgroSenseSmartConverter'\r\n ],\r\n fieldBorder: [\r\n 'FmxConverter',\r\n 'TmxConverter',\r\n 'TrimbleAgGPSConverter',\r\n 'TopConConverter',\r\n 'ShapeConverter',\r\n 'IsoxmlConverter',\r\n 'IsoXmlIntellview4Converter'\r\n ],\r\n soilMap: [\r\n 'ApplicationMapShapeConverter',\r\n 'IsoxmlConverter'\r\n ],\r\n sensorData: [\r\n 'GeoTiffConverter'\r\n ]\r\n}\r\n\r\nexport const validShapeConvertersForMultiDownload = [\r\n 'ShapeConverter',\r\n 'ApplicationMapShapeConverter',\r\n 'JohnDeereConverter',\r\n 'GeoTiffConverter'\r\n]\r\n\r\nexport const converterWithIncludeFieldBorderOption = [\r\n 'TrimbleAgGPSConverter',\r\n 'TmxConverter',\r\n 'IsoxmlConverter',\r\n 'IsoxmlAdvancedConverter',\r\n 'ISOxmlTopconConverter',\r\n 'IsoXmlIntellview4Converter'\r\n]\r\n","import axios from 'axios'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport convertToLegacyPayload from './convert-to-legacy-payload'\r\nimport {getKmlColors} from './get-kml-colors'\r\nimport {convertersByMapType, validShapeConvertersForMultiDownload, converterWithIncludeFieldBorderOption} from './valid-converters'\r\n\r\n/**\r\n * This module is part of the standard download flow.\r\n * It handles multiple parts:\r\n * - selecting which data to download\r\n * - showing the format selection modal\r\n * - server communication during the download flow\r\n *\r\n * for more details about the download flow see iXmap.Solutions.WebApp.Areas.DataTransfer.Controllers.DownloadController\r\n */\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n mapType: 'applicationMap',\r\n selectedMapIds: [],\r\n selectedConverter: null,\r\n\r\n fileName: null,\r\n description: '',\r\n ui: {\r\n showConverterModal: false\r\n },\r\n // props only for app map download\r\n includeFieldBorder: false,\r\n selectedUnit: null,\r\n srcUnit: null,\r\n validUnits: [],\r\n multipleFiles: true,\r\n multipleMapTypesWithMaizeSowing: false\r\n },\r\n getters: {\r\n validConverters (state, getters) {\r\n if (!getters.selectedMaps) return\r\n\r\n const everySelectedMapIsSensorData = getters.selectedMaps.every((element, index) => {\r\n return (getters.selectedMaps[index].category === 'InterpolatedSensorData')\r\n })\r\n\r\n if (everySelectedMapIsSensorData) {\r\n return convertersByMapType['sensorData']\r\n }\r\n\r\n return convertersByMapType[state.mapType]\r\n },\r\n selectedMaps (state, getters, rootState) {\r\n // map management uses a weird mish-mash of \"biomass maps are an explicitely separate map type\" and \"biomass maps are just zone maps with a different category\"\r\n // there is no separate map lookup for biomass, hence this workaround\r\n const workaroundMapType = state.mapType === 'biomassMap' ? 'zoneMap' : state.mapType\r\n\r\n const lookup = rootState.fieldRecordSystem.mapManagement.data[workaroundMapType].mapLookup\r\n\r\n return state.selectedMapIds.map(id => lookup[id])\r\n },\r\n validShapeConvertersForMultiDownload () {\r\n return validShapeConvertersForMultiDownload\r\n },\r\n converterWithIncludeFieldBorderOption () {\r\n return converterWithIncludeFieldBorderOption\r\n }\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'fileName',\r\n 'description',\r\n 'converterList',\r\n 'selectedConverter',\r\n 'selectedUnit',\r\n 'srcUnit',\r\n 'ui.showConverterModal',\r\n 'includeFieldBorder',\r\n 'validUnits',\r\n 'multipleFiles',\r\n 'multipleMapTypesWithMaizeSowing'\r\n ]),\r\n startDownload (state, {type, ids}) {\r\n state.description = ''\r\n state.mapType = type\r\n state.selectedMapIds = ids\r\n state.ui.showConverterModal = true\r\n },\r\n resetAppMapProps (state) {\r\n state.validUnits = []\r\n state.selectedUnit = null\r\n state.srcUnit = null\r\n state.multipleMapTypesWithMaizeSowing = false\r\n state.includeFieldBorder = false\r\n state.multipleFiles = true\r\n }\r\n },\r\n actions: {\r\n startDownload ({state, getters, commit, rootState}, {type, ids}) {\r\n if (type === 'applicationMap') {\r\n commit('resetAppMapProps')\r\n const units = rootState.masterData.units\r\n\r\n const mapsInfos = ids.map(id => {\r\n const map = rootState.fieldRecordSystem.mapManagement.data.applicationMap.mapLookup[id]\r\n const unit = map.unit\r\n const unitType = units[unit].type\r\n const unitShortcut = units[unit].shortcut\r\n const origin = map.origin\r\n\r\n return {\r\n unit,\r\n unitType,\r\n unitShortcut,\r\n origin\r\n }\r\n })\r\n\r\n const hasSameUnitType = mapsInfos.every((val, i, arr) => val.unitType === arr[0].unitType)\r\n const hasSameMapType = mapsInfos.every((val, i, arr) => val.origin === arr[0].origin)\r\n\r\n if (hasSameUnitType && hasSameMapType) {\r\n const unitShortcuts = Object.values(units).filter(unit => unit.type === mapsInfos[0].unitType).map(unit => unit.shortcut)\r\n // check if all maps have the same unit shortcut\r\n const hasSameUnitShortcut = mapsInfos.every((val, i, arr) => val.shortcut === arr[0].shortcut)\r\n\r\n commit('setValidUnits', unitShortcuts)\r\n commit('setSelectedUnit', hasSameUnitShortcut ? mapsInfos[0].unit : null)\r\n commit('setSrcUnit', hasSameUnitShortcut ? mapsInfos[0].unit : null)\r\n } else {\r\n // It´s a AGRAVIS feature WAA-1258\r\n // check if one of the maps is a maize sowing map\r\n const maizeSowingInfos = mapsInfos.filter(map => map.origin === 'MaizeSowing')\r\n if (maizeSowingInfos.length > 0) {\r\n // check if all maize sowing maps have the same unit shortcut\r\n const hasSameUnitShortcut = mapsInfos.every((val, i, arr) => val.shortcut === arr[0].shortcut)\r\n const unitShortcuts = Object.values(units).filter(unit => unit.type === maizeSowingInfos[0].unitType).map(unit => unit.shortcut)\r\n const selectedUnit = hasSameUnitShortcut ? maizeSowingInfos[0].unit : null\r\n const srcUnit = hasSameUnitShortcut ? maizeSowingInfos[0].unit : null\r\n\r\n commit('setValidUnits', unitShortcuts)\r\n commit('setSelectedUnit', selectedUnit)\r\n commit('setSrcUnit', srcUnit)\r\n // set server option\r\n commit('setMultipleMapTypesWithMaizeSowing', true)\r\n }\r\n }\r\n }\r\n\r\n commit('setMultipleFiles', true)\r\n commit('startDownload', {type, ids})\r\n\r\n if (!getters.validConverters.includes(state.selectedConverter)) {\r\n commit('setSelectedConverter', getters.validConverters[0])\r\n }\r\n // }\r\n },\r\n async download ({state, rootState, getters, rootGetters}) {\r\n const {fileName, description, selectedConverter, selectedUnit, includeFieldBorder, multipleFiles, mapType, multipleMapTypesWithMaizeSowing} = state\r\n const maps = getters.selectedMaps\r\n\r\n const urls = {\r\n applicationMap: '/api/v2/DataTransfer/Download/Convert/ApplicationMaps',\r\n zoneMap: '/api/v2/DataTransfer/Download/Convert/ZoneMaps',\r\n biomassMap: '/api/v2/DataTransfer/Download/Convert/BiomassMaps',\r\n nutrientMap: '/api/v2/DataTransfer/Download/Convert/NutrientMaps',\r\n fieldBorder: '/api/v2/DataTransfer/Download/Convert/Borders',\r\n soilMap: '/api/v2/DataTransfer/Download/Convert/SoilMaps',\r\n sensorRaster: '/api/v2/DataTransfer/Download/interpolation-maps'\r\n }\r\n\r\n if (mapType === 'soilMap') { // just for phbb sensor data\r\n const categories = maps.map(map => map.category)\r\n const hasSameCategory = categories.every((val, i, arr) => val === arr[0])\r\n\r\n if (hasSameCategory && categories[0] === 'InterpolatedSensorData') {\r\n const url = urls.sensorRaster\r\n\r\n const data = {\r\n fileName,\r\n mapIds: maps.map(map => map.id)\r\n }\r\n\r\n return axios.post(url, data).then(response => response.data)\r\n } else {\r\n if (categories.includes('InterpolatedSensorData')) {\r\n throw new Error('invalid selection: cannot select maps of type InterpolatedSensorData and other (soil) maps.')\r\n }\r\n }\r\n }\r\n\r\n const url = urls[mapType]\r\n const fieldIdsByMapId = rootGetters['fieldRecordSystem/mapManagement/fieldIdsByMapId']\r\n const useFieldBorder = mapType !== 'applicationMap' ? true : includeFieldBorder\r\n\r\n const data = convertToLegacyPayload(mapType, {\r\n selectedConverter,\r\n fileName,\r\n description,\r\n maps,\r\n harvestYear: rootState.fieldRecordSystem.userSettings.harvestYear,\r\n includeFieldBorder: useFieldBorder,\r\n selectedUnit,\r\n multipleFiles,\r\n multipleMapTypesWithMaizeSowing\r\n }, fieldIdsByMapId)\r\n\r\n if (['KmlConverter', 'KmzConverter'].includes(selectedConverter)) {\r\n const applicationMapPalette = rootGetters['fieldRecordSystem/mapManagement/applicationMapPalette']\r\n const zoneMapPalette = rootGetters['fieldRecordSystem/mapManagement/zoneMapPalette']\r\n\r\n data.colorPaletteByMap = await getKmlColors(maps, mapType, applicationMapPalette, zoneMapPalette)\r\n }\r\n\r\n return axios.post(url, data).then(response => response.data)\r\n\r\n }\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n ...makeSetters([\r\n 'data.selectedMetaData',\r\n 'data.metaDataAll',\r\n 'data.measurements'\r\n ]),\r\n setMetaDataAll (state, data) {\r\n /*\r\n production: harvest...\r\n application: fertilization, seeding...\r\n */\r\n const applications = data.applicationMetaData.map(x => ({...x, type: 'application'}))\r\n const productions = data.productionMetaData.map(x => ({...x, type: 'production'}))\r\n const applicationMapData = data.applicationMapData.map(x => ({...x, type: 'applicationMap'}))\r\n state.data.metaDataAll = applications.concat(productions).concat(applicationMapData)\r\n },\r\n deleteTelemetry (state) {\r\n const index = state.data.metaDataAll.findIndex(x => x.id === state.data.selectedMetaData.id)\r\n state.data.metaDataAll.splice(index, 1)\r\n state.data.selectedMetaData = null\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport default {\r\n showTelemetryOverview ({commit, rootGetters, rootState}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n return smarterGet('/api/v2/telemetry/orgunits/{orgUnitId}/{fieldId}/metadata/all/{harvestYear}', {\r\n id: 'telemetry.metadata',\r\n expiry: 0,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n fieldId: () => fieldId,\r\n harvestYear: () => harvestYear\r\n },\r\n onResult (metaData) {\r\n commit('setMetaDataAll', metaData)\r\n commit('fieldRecordSystem/setRightView', 'telemetry', {root: true})\r\n }\r\n })\r\n },\r\n deleteTelemetry ({state, commit, rootGetters}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const id = state.data.selectedMetaData.id\r\n axios.delete(`/api/v2/telemetry/orgunits/${orgUnitId}/${state.data.selectedMetaData.type}/${id}`)\r\n .then(() => {\r\n commit('deleteTelemetry')\r\n })\r\n },\r\n getMeasurements ({state, commit, rootGetters}) {\r\n const isApplication = state.data.selectedMetaData.type === 'application'\r\n const id = state.data.selectedMetaData.id\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n\r\n const url = isApplication ? '/api/v2/telemetry/orgunits/{orgUnitId}/application/{id}/measurements' : '/api/v2/telemetry/orgunits/{orgUnitId}/production/{id}/measurements'\r\n return smarterGet(url, {\r\n id: 'telemetry.measurements',\r\n expiry: 0,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n id: () => id\r\n },\r\n onResult (measurements) {\r\n commit('setMeasurements', measurements)\r\n }\r\n })\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {toWkt, geoJsonFormat} from '@helpers/openlayers/features'\r\n\r\nimport moment from 'moment'\r\n\r\nexport default {\r\n importYieldData ({commit}, geojson) {\r\n const features = geoJsonFormat.readFeatures(geojson, {dataProjection: 'EPSG:4326', featureProjection: 'EPSG:3857'})\r\n commit('importYieldData', features)\r\n },\r\n save ({state, commit, rootGetters}) {\r\n const measurements = state.features.map((feature) => {\r\n return {\r\n value: parseFloat(feature.getProperties()[state.valueKey.value]),\r\n timestamp: state.timestampKey ? moment(Date(feature.getProperties()[state.timestampKey.value])) : feature.getProperties()[state.timestampKey],\r\n geometry: toWkt(feature)\r\n }\r\n })\r\n\r\n const {name, date: creation, cropUsageId, productId, unit} = state\r\n\r\n const metadata = {name, creation, cropUsageId, productId, unit}\r\n\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const url = `/api/v2/telemetry/orgunits/${orgUnitId}/${fieldId}/${state.type.value}`\r\n\r\n return axios.post(url, {measurements, metadata})\r\n .then(commit('reset'))\r\n .then(commit('fieldRecordSystem/setRightView', 'telemetry', {root: true}))\r\n }\r\n}\r\n","import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n ...makeSetters([\r\n 'productId',\r\n 'cropUsageId',\r\n 'date',\r\n 'type',\r\n 'name',\r\n 'valueKey',\r\n 'timestampKey',\r\n 'unit'\r\n ]),\r\n reset (state) {\r\n state.name = ''\r\n state.date = null\r\n state.productId = null\r\n state.cropUsageId = null\r\n state.features = null\r\n state.valueKey = null\r\n state.timestampKey = null\r\n state.unit = 'kg/ha'\r\n },\r\n importYieldData (state, features) {\r\n state.features = features\r\n }\r\n}\r\n","import actions from './actions'\r\nimport mutations from './mutations'\r\n\r\nconst typeOptions = [\r\n {value: 'application', text: 'Dünger'},\r\n {value: 'production', text: 'Ernte'}\r\n]\r\n\r\nconst state = {\r\n name: '',\r\n date: null,\r\n productId: null,\r\n cropUsageId: null,\r\n valueKey: null,\r\n timestampKey: null,\r\n features: null,\r\n type: typeOptions[0],\r\n typeOptions: typeOptions,\r\n unit: 'kg/ha'\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations\r\n}\r\n","import mutations from './mutations'\r\nimport actions from './actions'\r\n\r\nimport dataImport from './data-import'\r\n\r\nconst state = {\r\n data: {\r\n metaDataAll: null,\r\n selectedMetaData: null,\r\n measurements: null\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n modules: {\r\n dataImport\r\n }\r\n}\r\n","// import {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\nimport newGuid from '@helpers/new-guid'\r\n\r\nconst fertilizationDefaults = () => ({\r\n id: null,\r\n minValue: null,\r\n maxValue: null,\r\n selectedYieldMapId: null,\r\n actualYield: null,\r\n number: null,\r\n name: ''\r\n})\r\n\r\nconst defaults = () => ({\r\n data: {\r\n applicationMetaData: [],\r\n yieldMetaData: []\r\n },\r\n creation: {\r\n yieldData: [],\r\n applicationData: [],\r\n numberZones: 5,\r\n numberYears: 3,\r\n maxApplicationValue: null,\r\n mapName: null,\r\n productId: null\r\n },\r\n applicationDetails: {\r\n selectedMapId: null,\r\n id: null,\r\n minValue: null,\r\n maxValue: null,\r\n withdrawalFactor: null,\r\n number: null,\r\n name: ''\r\n },\r\n yieldDetails: {\r\n id: null,\r\n minValue: null,\r\n maxValue: null,\r\n selectedYieldMapId: null,\r\n actualYield: null,\r\n pFactor: null,\r\n number: null,\r\n name: ''\r\n }\r\n})\r\n\r\nexport default {\r\n ...makeSetters([\r\n 'creation.numberZones',\r\n 'creation.numberYears',\r\n 'creation.maxValue',\r\n 'creation.maxApplicationValue',\r\n 'creation.mapName',\r\n 'creation.productId',\r\n 'applicationDetails.id',\r\n 'applicationDetails.withdrawalFactor',\r\n 'applicationDetails.selectedMapId',\r\n 'yieldDetails.minValue',\r\n 'yieldDetails.maxValue',\r\n 'yieldDetails.selectedYieldMapId',\r\n 'yieldDetails.actualYield',\r\n 'yieldDetails.pFactor',\r\n 'yieldDetails.number'\r\n ]),\r\n setApplicationMinValue (state, value) {\r\n state.applicationDetails.minValue = value\r\n },\r\n setApplicationMaxValue (state, value) {\r\n state.applicationDetails.maxValue = value\r\n },\r\n setApplicationDetails (state) {\r\n let applicationDetails = {\r\n\r\n minValue: state.applicationDetails.minValue,\r\n maxValue: state.applicationDetails.maxValue,\r\n withdrawalFactor: state.applicationDetails.withdrawalFactor,\r\n name: state.applicationDetails.name,\r\n number: state.applicationDetails.number,\r\n selectedMapId: state.applicationDetails.selectedMapId\r\n }\r\n if (state.applicationDetails.id) {\r\n applicationDetails.id = state.applicationDetails.id\r\n\r\n const index = state.creation.applicationData.indexOf(x => x.id === state.applicationDetails.id)\r\n state.creation.applicationData.splice(index, 1, {...applicationDetails})\r\n } else {\r\n applicationDetails.id = newGuid()\r\n state.creation.applicationData.push(applicationDetails)\r\n }\r\n },\r\n setApplicationName (state, value) {\r\n state.applicationDetails.name = value\r\n },\r\n setApplicationNumber (state, value) {\r\n state.applicationDetails.number = value\r\n },\r\n reset (state) {\r\n Object.assign(state, defaults())\r\n },\r\n resetApplicationData (state) {\r\n state.applicationDetails.selectedMapId = null\r\n state.applicationDetails.id = null\r\n state.applicationDetails.minValue = null\r\n state.applicationDetails.maxValue = null\r\n state.applicationDetails.withdrawalFactor = null\r\n state.applicationDetails.number = null\r\n state.applicationDetails.name = null\r\n },\r\n setApplicationData (state, data) {\r\n state.applicationDetails.id = data.id\r\n state.applicationDetails.minValue = data.minValue\r\n state.applicationDetails.maxValue = data.maxValue\r\n state.applicationDetails.withdrawalFactor = data.withdrawalFactor\r\n state.applicationDetails.number = data.number\r\n state.applicationDetails.name = data.name\r\n state.applicationDetails.selectedMapId = data.selectedMapId\r\n },\r\n setApplicationMetaData (state, data) {\r\n const applications = data.applicationMetaData.map(x => ({...x, type: 'application'}))\r\n const productions = data.productionMetaData.map(x => ({...x, type: 'production'}))\r\n const applicationMapData = data.applicationMapData.map(x => ({...x, type: 'applicationMap'}))\r\n state.data.applicationMetaData = applications.concat(applicationMapData)\r\n state.data.yieldMetaData = productions\r\n },\r\n setYieldName (state, value) {\r\n state.yieldDetails.name = value\r\n },\r\n resetYieldDetails (state, yieldData = fertilizationDefaults()) {\r\n Object.assign(state.yieldDetails, yieldData)\r\n },\r\n updateYieldDataList (state) {\r\n if (!state.yieldDetails.id) {\r\n state.yieldDetails.id = newGuid()\r\n state.creation.yieldData.push({...state.yieldDetails})\r\n } else {\r\n const index = state.creation.yieldData.indexOf(x => x.id === state.yieldDetails.id)\r\n state.creation.yieldData.splice(index, 1, {...state.yieldDetails})\r\n }\r\n },\r\n removeYieldCard (state, fertilizationDataId) {\r\n state.creation.yieldData = state.creation.yieldData.filter(x => x.id !== fertilizationDataId)\r\n },\r\n removeProductionCard (state, applicationDataId) {\r\n state.creation.applicationData = state.creation.applicationData.filter(x => x.id !== applicationDataId)\r\n }\r\n}\r\n","import axios from 'axios'\r\n\r\nimport {smarterGet} from '@helpers/vuex/data-loading'\r\n\r\nexport default {\r\n saveYieldDetails ({state, rootState, commit}) {\r\n if (!state.yieldDetails.id) {\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n const year = harvestYear - state.creation.yieldData.length - 1\r\n commit('setNumber', year)\r\n }\r\n\r\n const selectedMap = state.data.yieldMetaData.find(x => x.id === state.yieldDetails.selectedYieldMapId)\r\n if (selectedMap) commit('setYieldName', selectedMap.name)\r\n\r\n commit('updateYieldDataList')\r\n commit('resetYieldDetails')\r\n commit('fieldRecordSystem/setRightView', 'simonModule', {root: true})\r\n },\r\n saveProductionDetails ({state, commit}) {\r\n const selectedMap = state.data.applicationMetaData.find(x => x.id === state.applicationDetails.selectedMapId)\r\n\r\n if (selectedMap) commit('setApplicationName', selectedMap.name)\r\n if (!state.applicationDetails.id) {\r\n const length = state.creation.applicationData.length\r\n commit('setApplicationNumber', length + 1)\r\n }\r\n commit('setApplicationDetails')\r\n },\r\n startSimonModule ({commit, rootGetters, rootState}) {\r\n const orgUnitId = rootGetters['fieldRecordSystem/orgUnitId']\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n const {harvestYear} = rootState.fieldRecordSystem.userSettings\r\n\r\n return smarterGet('/api/v2/telemetry/orgunits/{orgUnitId}/{fieldId}/metadata/all/{harvestYear}', {\r\n id: 'telemetry.metadata',\r\n expiry: 0,\r\n inputs: {\r\n orgUnitId: () => orgUnitId,\r\n fieldId: () => fieldId,\r\n harvestYear: () => harvestYear\r\n },\r\n onResult (metaData) {\r\n commit('reset')\r\n commit('setApplicationMetaData', metaData)\r\n commit('fieldRecordSystem/setRightView', 'simonModule', {root: true})\r\n }\r\n })\r\n },\r\n startComputation ({state, rootGetters}) {\r\n const fieldId = rootGetters['fieldRecordSystem/fieldId']\r\n return axios.post('/api/v2/mapcreation/simon', Object.assign({fieldId}, state.creation))\r\n .then(result => result.data)\r\n },\r\n startAddApplicationMap ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationDetails', {root: true})\r\n },\r\n viewResultPage ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'applicationMapCreationResultSimon', {root: true})\r\n },\r\n goBackToSimon ({commit}) {\r\n commit('fieldRecordSystem/setRightView', 'simonModule', {root: true})\r\n }\r\n}\r\n","import mutations from './mutations'\r\nimport actions from './actions'\r\n\r\nconst state = {\r\n data: {\r\n applicationMetaData: [],\r\n yieldMetaData: []\r\n },\r\n creation: {\r\n yieldData: [],\r\n applicationData: [],\r\n numberZones: 5,\r\n numberYears: 3,\r\n maxApplicationValue: null,\r\n mapName: null,\r\n productId: null\r\n },\r\n applicationDetails: {\r\n selectedMapId: null,\r\n id: null,\r\n minValue: null,\r\n maxValue: null,\r\n withdrawalFactor: null,\r\n number: null,\r\n name: ''\r\n },\r\n yieldDetails: {\r\n id: null,\r\n minValue: null,\r\n maxValue: null,\r\n selectedYieldMapId: null,\r\n actualYield: null,\r\n pFactor: null,\r\n number: null,\r\n name: ''\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n modules: {\r\n // more sub-modules\r\n }\r\n}\r\n","import axios from 'axios'\r\nimport {makeSetters} from '@helpers/vuex/mutations'\r\n\r\nexport default {\r\n namespaced: true,\r\n state: {\r\n fields: []\r\n },\r\n mutations: {\r\n ...makeSetters([\r\n 'fields'\r\n ])\r\n },\r\n actions: {\r\n loadMigratedFields ({state, commit, rootState}) {\r\n const harvestYear = rootState.fieldRecordSystem.userSettings.harvestYear\r\n axios.get(`/api/v2/frs/${harvestYear}/fields/migration`)\r\n .then(response => response.data)\r\n .then((fields) => {\r\n commit('setFields', fields)\r\n })\r\n }\r\n }\r\n}\r\n","export default {\r\n field: {\r\n cultivationPlan: 'cultivationsDisplayField'\r\n },\r\n orgUnit: {\r\n cultivationsDisplayField: 'cultivationPlan'\r\n },\r\n back: {\r\n cultivationPlanning: 'cultivationsDisplayField',\r\n mixtureManagement: 'cultivationPlanning',\r\n actionPlanningFromOverview: 'actionOverview',\r\n actionPlanningFromCollection: 'annualPlan',\r\n actionPlanningFromDiff: 'annualPlanDiff',\r\n actionPlanningForSingleFieldFromList: 'actionDisplayField',\r\n actionPlanningForSingleField: 'actionDisplayField',\r\n actionDetails: 'actionDisplayField',\r\n actionDetailsPage: 'actionDisplayField',\r\n probingOrderExport: 'basicFertilization',\r\n probingResultManualSettings: 'basicFertilization',\r\n probingResultManualValues: 'basicFertilization',\r\n probingResultUpload: 'basicFertilization',\r\n nutrientMapDisplay: 'basicFertilization',\r\n cultivationPlanningFromOrgUnit: 'cultivationPlan',\r\n lanePlanExport: 'lanePlanSelectionOrgUnit',\r\n lanePlanDetail: 'lanePlanSelectionOrgUnit'\r\n },\r\n escape: {\r\n cultivationPlanning: 'cultivationsDisplayField',\r\n mixtureManagement: 'cultivationsDisplayField',\r\n cultivationPlanningFromOrgUnit: 'cultivationPlan',\r\n companyData: 'default',\r\n companyNumbers: 'default',\r\n actionPlanningForSingleField: 'default',\r\n actionDetailsPage: 'actionDisplayField'\r\n }\r\n}\r\n","import mutations from './mutations'\r\nimport * as actions from './actions'\r\nimport * as getters from './getters'\r\nimport navigation from './navigation'\r\nimport cultivationPlanning from './cultivation-planning'\r\nimport cultivationOverview from './cultivation-overview'\r\nimport action from './action'\r\nimport machines from './machines'\r\nimport persons from './persons'\r\nimport map from './map'\r\nimport lanePlanning from './lane-planning'\r\nimport nutrientRequirement from './nutrient-requirement'\r\nimport basicFertilization from './basic-fertilization'\r\nimport fieldDetails from './field-details'\r\nimport companyData from './company-data'\r\nimport nutritionStatus from './nutrition-status'\r\nimport simpleApplicationMaps from './simple-application-maps'\r\nimport maizeSowing from './maize-sowing'\r\nimport soilDetail from './soil-detail'\r\nimport entityImport from './entity-import'\r\nimport defaultYields from './default-yields'\r\nimport applicationMaps from './application-maps'\r\nimport download from './download'\r\nimport telemetry from './telemetry'\r\nimport simonModule from './simon-module'\r\nimport mapManagement from './map-management'\r\nimport migration from './migration'\r\n\r\nimport transitions from './transitions'\r\n\r\nconst state = {\r\n ui: {\r\n transitions,\r\n view: {\r\n left: 'rocket', // 'rocket', 'legacy', 'groups'\r\n right: 'default',\r\n expanded: false,\r\n rightCollapsed: false,\r\n leftCollapsed: false\r\n },\r\n filter: {\r\n cultivation: {}\r\n },\r\n workflow: null,\r\n waitscreen: false,\r\n loadingData: false,\r\n mainPageLoading: false,\r\n geometryEditing: {\r\n active: false,\r\n component: null\r\n },\r\n gettingZoneMap: false,\r\n entityStructureEditing: false\r\n },\r\n userSettings: {\r\n harvestYear: null,\r\n tags: {\r\n fields: {}\r\n },\r\n favorites: {\r\n cropUsages: [],\r\n products: []\r\n },\r\n ui: {}\r\n },\r\n data: {\r\n orgUnits: {\r\n // TODO pull upwards when references are fixed\r\n data: {}\r\n },\r\n field: {},\r\n crops: {},\r\n soilTypes: [],\r\n soilSubTypes: [],\r\n usageTypes: [],\r\n companyForms: [],\r\n legalForms: [],\r\n waterExtractionSources: []\r\n },\r\n permissions: [],\r\n cropRotations: {\r\n root: [],\r\n company: [],\r\n field: null\r\n }\r\n}\r\n\r\nexport default {\r\n namespaced: true,\r\n state,\r\n actions,\r\n mutations,\r\n getters,\r\n modules: {\r\n navigation,\r\n cultivationPlanning,\r\n cultivationOverview,\r\n action,\r\n machines,\r\n persons,\r\n map,\r\n lanePlanning,\r\n nutrientRequirement,\r\n basicFertilization,\r\n fieldDetails,\r\n companyData,\r\n nutritionStatus,\r\n soilDetail,\r\n entityImport,\r\n defaultYields,\r\n simpleApplicationMaps,\r\n maizeSowing,\r\n applicationMaps,\r\n download,\r\n telemetry,\r\n simonModule,\r\n mapManagement,\r\n migration\r\n }\r\n}\r\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","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\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 getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","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","/**\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","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\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 baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nmodule.exports = baseIteratee;\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 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 nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\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}","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */\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","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\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","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\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('@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;","export const actionHierarchy = {\r\n seeding: {\r\n broad: {\r\n steps: ['seedingBroadDrillSingle'],\r\n defaults: () => ({\r\n plantsPerSqm: 0,\r\n emergence: 0, // TODO proper name\r\n coating: null,\r\n // grain\r\n thousandSeedWeight: 0, // [g]\r\n seedsPerSqm: 0,\r\n germinationCapacity: 0,\r\n // corn\r\n rowSeparation: 0, // [cm]\r\n rowDistance: 0, // [cm]\r\n // seedProduct: null,\r\n mixtureComponents: []\r\n })\r\n },\r\n drill: 'broad',\r\n single: 'broad',\r\n set: {\r\n steps: ['seedingSetPlant'],\r\n defaults: () => ({\r\n rowSeparation: 0, // [cm]\r\n rowDistance: 0, // [cm]\r\n plantsPerSqm: 0,\r\n totalPlants: 0, // may be calculated from rest\r\n packageSize: 0, // number of plants per retail package\r\n mixtureComponents: []\r\n })\r\n },\r\n plant: 'set',\r\n stripTill: 'broad',\r\n cornCloseSeed: 'broad',\r\n mulch: 'broad',\r\n other: {\r\n steps: ['seedingOther'],\r\n defaults: () => ({\r\n plantsPerSqm: 0,\r\n rowSeparation: 0, // [cm]\r\n rowDistance: 0, // [cm]\r\n emergence: 0, // TODO proper name\r\n germinationCapacity: 0,\r\n coating: null,\r\n mixtureComponents: []\r\n }) // TODO\r\n }\r\n },\r\n tillage: {\r\n schlegeln: 'other', // TODO proper name\r\n plowing: 'other',\r\n grubbern: 'other', // TODO proper name\r\n eggen: 'other', // TODO proper name\r\n basic: 'other',\r\n stoppelsturz: 'other', // TODO proper name\r\n seedbed: 'other',\r\n walzen: 'other', // TODO proper name\r\n stripTill: 'other',\r\n scheibeneggen: 'other',\r\n fraesen: 'other', // TODO proper name\r\n kreiseleggen: 'other',\r\n other: {steps: []}\r\n },\r\n protection: {\r\n hacken: {steps: []}, // TODO proper name\r\n harrow: 'hacken',\r\n other: 'hacken',\r\n spray: {\r\n steps: ['protectionSpray'],\r\n defaults: () => ({\r\n bbch: null // NOTE EC-Stadium\r\n })\r\n },\r\n },\r\n maintenance: {\r\n mulchenSchlaegeln: 'other',\r\n schleppen: 'other', // TODO proper name\r\n walzen: 'other', // TODO proper name\r\n vertikutieren: 'other', // TODO proper name\r\n other: {steps: []}\r\n },\r\n irrigation: {\r\n pipe: {\r\n steps: ['irrigation'],\r\n defaults: () => ({\r\n waterAmount: 0,\r\n waterExtraction: null\r\n }) // NOTE unit is currently fixed to mm/m²\r\n },\r\n circular: 'pipe',\r\n linear: 'pipe',\r\n drum: 'pipe',\r\n jet: 'pipe',\r\n drip: 'pipe',\r\n spray: 'pipe',\r\n underground: 'pipe',\r\n mobile: 'pipe',\r\n other: 'pipe',\r\n },\r\n transport: {\r\n steps: ['transport'],\r\n defaults: () => ({\r\n cargoType: 'general',\r\n internal: true,\r\n amount: {\r\n value: 0,\r\n unit: 'kg'\r\n },\r\n origin: '', // NOTE geo point at a later stage, text for now\r\n destination: '', // NOTE geo point at a later stage, text for now,\r\n distance: 0\r\n })\r\n },\r\n harvest: {\r\n maehdrusch: {\r\n steps: ['harvestQuality', 'harvestOther'],\r\n defaults: () => ({\r\n // TODO ASK-2813 rename to mainProduct or similar, including migration for existing data\r\n mainCropYield: {\r\n amount: null,\r\n unit: 'dt/ha'\r\n },\r\n // TODO ASK-2813 rename to byProduct or similar, including migration for existing data\r\n catchCropYield: { // NOTE refers only to the by-product that is actually transported off of the field, **not** the part that stays on the field\r\n amount: null,\r\n unit: 'dt/ha'\r\n },\r\n cropUsageId: null,\r\n cropHarvestQualityId: null,\r\n actualQuality: {\r\n moisture: null,\r\n dryMatter: null,\r\n protein: null,\r\n sugar: null,\r\n correctedSugar: null,\r\n starch: null,\r\n sedimentation: null,\r\n adhesiveProtein: null,\r\n lipid: null,\r\n fiber: null,\r\n weight: null,\r\n ash: null,\r\n brokenGrains: null,\r\n fallingNumber: null,\r\n impurity: null,\r\n wetAdhesiveProtein: null,\r\n mycotoxins: null,\r\n }\r\n })\r\n }, // TODO proper name\r\n gruenlandSchnitt: {\r\n steps: ['harvestQuality', 'harvestGrassLand'],\r\n defaults: () => ({\r\n cutNumber: null,\r\n cuttingTime: 'early',\r\n grassYield: {\r\n amount: null,\r\n unit: 'dt/ha'\r\n },\r\n cropUsageId: null,\r\n cropHarvestQualityId: null\r\n })\r\n },\r\n roden: 'maehdrusch', // TODO proper name\r\n schneiden: 'maehdrusch', // TODO proper name\r\n buendeln: 'maehdrusch', // TODO proper name\r\n haeckseln: 'maehdrusch', // TODO proper name\r\n pressen: 'maehdrusch', // TODO proper name\r\n pfluecken: 'maehdrusch', // TODO proper name\r\n stechen: 'maehdrusch', // TODO proper name\r\n wenden: 'maehdrusch', // TODO proper name\r\n schwaden: 'maehdrusch', // TODO proper name\r\n silieren: 'maehdrusch', // TODO proper name,\r\n other: 'maehdrusch'\r\n },\r\n fertilization: {\r\n mineral: {\r\n steps: ['fertilizationType', 'fertilizationAmount'],\r\n defaults: () => ({\r\n fertilizerData: {\r\n density: null\r\n },\r\n fertilizerNutrientContents: {\r\n nitrogen: 0,\r\n phosphorus: 0,\r\n potassium: 0,\r\n magnesium: 0,\r\n sulphur: 0,\r\n // parts of N, N >= nitrate + ammonium + amide\r\n nitrate: 0,\r\n ammonium: 0,\r\n nitrogenAmide: 0\r\n },\r\n isLiquid: false,\r\n applicationMethod: 'spreader_1',\r\n useCustomProduct: false,\r\n customProductName: null\r\n })\r\n },\r\n organic: 'mineral'\r\n },\r\n other: {\r\n steps: []\r\n }\r\n}\r\n\r\nconst getSettings = (type, procedure) => {\r\n const settingsOrAlias = actionHierarchy[type].steps\r\n ? actionHierarchy[type]\r\n : actionHierarchy[type][procedure] || {}\r\n\r\n return typeof settingsOrAlias === 'string'\r\n ? actionHierarchy[type][settingsOrAlias]\r\n : settingsOrAlias\r\n}\r\n\r\nexport function procedureParameterDefaults (type, procedure) {\r\n const settings = getSettings(type, procedure)\r\n\r\n return settings.defaults ? settings.defaults() : {}\r\n}\r\n\r\nexport function procedureParameterSteps (type, procedure) {\r\n if (!type) return []\r\n\r\n const settings = getSettings(type, procedure)\r\n\r\n return settings.steps ? settings.steps : []\r\n}\r\n\r\nexport function types () {\r\n return Object.keys(actionHierarchy)\r\n}\r\n\r\nexport function procedures (type) {\r\n return actionHierarchy[type].steps\r\n ? []\r\n : Object.keys(actionHierarchy[type])\r\n}\r\n","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 eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\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 ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","\"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 * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\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 MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","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","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\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};","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","\"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 hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\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 castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseGet = require('./_baseGet');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nmodule.exports = basePropertyDeep;\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 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","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\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 arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\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 * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\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","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = baseProperty;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\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","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 isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\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 baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\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 assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\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 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","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n"],"sourceRoot":""}