| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | 
							- "use strict";
 
- var __importDefault = (this && this.__importDefault) || function (mod) {
 
-     return (mod && mod.__esModule) ? mod : { "default": mod };
 
- };
 
- Object.defineProperty(exports, "__esModule", { value: true });
 
- var helpers_1 = require("@turf/helpers");
 
- var invariant_1 = require("@turf/invariant");
 
- var polygon_clipping_1 = __importDefault(require("polygon-clipping"));
 
- /**
 
-  * Takes two {@link Polygon|polygon} or {@link MultiPolygon|multi-polygon} geometries and
 
-  * finds their polygonal intersection. If they don't intersect, returns null.
 
-  *
 
-  * @name intersect
 
-  * @param {Feature<Polygon | MultiPolygon>} poly1 the first polygon or multipolygon
 
-  * @param {Feature<Polygon | MultiPolygon>} poly2 the second polygon or multipolygon
 
-  * @param {Object} [options={}] Optional Parameters
 
-  * @param {Object} [options.properties={}] Translate GeoJSON Properties to Feature
 
-  * @returns {Feature|null} returns a feature representing the area they share (either a {@link Polygon} or
 
-  * {@link MultiPolygon}). If they do not share any area, returns `null`.
 
-  * @example
 
-  * var poly1 = turf.polygon([[
 
-  *   [-122.801742, 45.48565],
 
-  *   [-122.801742, 45.60491],
 
-  *   [-122.584762, 45.60491],
 
-  *   [-122.584762, 45.48565],
 
-  *   [-122.801742, 45.48565]
 
-  * ]]);
 
-  *
 
-  * var poly2 = turf.polygon([[
 
-  *   [-122.520217, 45.535693],
 
-  *   [-122.64038, 45.553967],
 
-  *   [-122.720031, 45.526554],
 
-  *   [-122.669906, 45.507309],
 
-  *   [-122.723464, 45.446643],
 
-  *   [-122.532577, 45.408574],
 
-  *   [-122.487258, 45.477466],
 
-  *   [-122.520217, 45.535693]
 
-  * ]]);
 
-  *
 
-  * var intersection = turf.intersect(poly1, poly2);
 
-  *
 
-  * //addToMap
 
-  * var addToMap = [poly1, poly2, intersection];
 
-  */
 
- function intersect(poly1, poly2, options) {
 
-     if (options === void 0) { options = {}; }
 
-     var geom1 = invariant_1.getGeom(poly1);
 
-     var geom2 = invariant_1.getGeom(poly2);
 
-     var intersection = polygon_clipping_1.default.intersection(geom1.coordinates, geom2.coordinates);
 
-     if (intersection.length === 0)
 
-         return null;
 
-     if (intersection.length === 1)
 
-         return helpers_1.polygon(intersection[0], options.properties);
 
-     return helpers_1.multiPolygon(intersection, options.properties);
 
- }
 
- exports.default = intersect;
 
 
  |