tmp-react-map-gl-draw
Version:
A lite version editing layer with react
112 lines (88 loc) • 13.3 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.isNumeric = isNumeric;
exports.parseEventElement = parseEventElement;
exports.getScreenCoords = getScreenCoords;
exports.findClosestPointOnLineSegment = findClosestPointOnLineSegment;
exports.getFeatureCoordinates = getFeatureCoordinates;
exports.updateRectanglePosition = updateRectanglePosition;
var _constants = require("../constants");
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
function isNumeric(val) {
return !Array.isArray(val) && !isNaN(parseFloat(val)) && isFinite(val);
}
function parseEventElement(evt) {
var elem = evt.target;
if (!elem || !elem.dataset || !elem.dataset.type) {
return null;
}
var type = elem.dataset.type;
var featureIndex = elem.dataset.featureIndex;
var index = elem.dataset.index;
return {
object: {
type: type,
index: isNumeric(index) ? Number(index) : undefined,
featureIndex: isNumeric(featureIndex) ? Number(featureIndex) : undefined
},
index: index
};
}
function getScreenCoords(evt) {
var _evt$offsetCenter = evt.offsetCenter,
x = _evt$offsetCenter.x,
y = _evt$offsetCenter.y;
return [Number(x), Number(y)];
}
function findClosestPointOnLineSegment(p1, p2, p) {
// line
var k = (p2[1] - p1[1]) / (p2[0] - p1[0]);
var b = p1[1] - k * p1[0]; // vertical line
if (!isFinite(k)) {
var q = [p1[0], p[1]];
return inBounds(p1, p2, q) ? q : null;
} // p is on line [p1, p2]
if (p[0] * k + b - p[1] === 0) {
return inBounds(p1, p2, p) ? p : null;
}
var qx = (k * p[1] + p[0] - k * b) / (k * k + 1);
var qy = k * qx + b;
return inBounds(p1, p2, [qx, qy]) ? [qx, qy] : null;
}
function getFeatureCoordinates(feature) {
var coordinates = feature && feature.geometry && feature.geometry.coordinates;
if (!coordinates) {
return null;
}
var isPolygonal = feature.geometry.type === _constants.GEOJSON_TYPE.POLYGON;
return isPolygonal ? coordinates[0] : coordinates;
}
function updateRectanglePosition(feature, editHandleIndex, mapCoords) {
var coordinates = getFeatureCoordinates(feature);
if (!coordinates) {
return null;
}
var points = coordinates.slice(0, 4);
points[editHandleIndex % 4] = mapCoords;
/*
* p0.x, p0.y (p0) ------ p2.x, p0.y (p1)
* | |
* | |
* p0.x, p2.y (p3) ----- p2.x, p2.y (p2)
*/
var p0 = points[(editHandleIndex + 2) % 4];
var p2 = points[editHandleIndex % 4];
points[(editHandleIndex + 1) % 4] = [p2[0], p0[1]];
points[(editHandleIndex + 3) % 4] = [p0[0], p2[1]];
return feature.geometry.type === _constants.GEOJSON_TYPE.POLYGON ? [[].concat(_toConsumableArray(points), [points[0]])] : points;
}
function inBounds(p1, p2, p) {
var bounds = [Math.min(p1[0], p2[0]), Math.max(p1[0], p2[0]), Math.min(p1[1], p2[1]), Math.max(p1[1], p2[1])];
return p[0] >= bounds[0] && p[0] <= bounds[1] && p[1] >= bounds[2] && p[1] <= bounds[3];
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/edit-modes/utils.js"],"names":["isNumeric","val","Array","isArray","isNaN","parseFloat","isFinite","parseEventElement","evt","elem","target","dataset","type","featureIndex","index","object","Number","undefined","getScreenCoords","offsetCenter","x","y","findClosestPointOnLineSegment","p1","p2","p","k","b","q","inBounds","qx","qy","getFeatureCoordinates","feature","coordinates","geometry","isPolygonal","GEOJSON_TYPE","POLYGON","updateRectanglePosition","editHandleIndex","mapCoords","points","slice","p0","bounds","Math","min","max"],"mappings":"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","sourcesContent":["// @flow\n\nimport type { MjolnirEvent } from 'mjolnir.js';\nimport type { Feature, Position } from '@nebula.gl/edit-modes';\n\nimport { GEOJSON_TYPE } from '../constants';\n\nexport function isNumeric(val: any) {\n  return !Array.isArray(val) && !isNaN(parseFloat(val)) && isFinite(val);\n}\n\nexport function parseEventElement(evt: MjolnirEvent) {\n  const elem = evt.target;\n  if (!elem || !elem.dataset || !elem.dataset.type) {\n    return null;\n  }\n\n  const type = elem.dataset.type;\n  const featureIndex = elem.dataset.featureIndex;\n  const index = elem.dataset.index;\n\n  return {\n    object: {\n      type,\n      index: isNumeric(index) ? Number(index) : undefined,\n      featureIndex: isNumeric(featureIndex) ? Number(featureIndex) : undefined\n    },\n    index\n  };\n}\n\nexport function getScreenCoords(evt: MjolnirEvent) {\n  const {\n    offsetCenter: { x, y }\n  } = evt;\n  return [Number(x), Number(y)];\n}\n\nexport function findClosestPointOnLineSegment(p1: Position, p2: Position, p: Position) {\n  // line\n  const k = (p2[1] - p1[1]) / (p2[0] - p1[0]);\n  const b = p1[1] - k * p1[0];\n\n  // vertical line\n  if (!isFinite(k)) {\n    const q = [p1[0], p[1]];\n    return inBounds(p1, p2, q) ? q : null;\n  }\n\n  // p is on line [p1, p2]\n  if (p[0] * k + b - p[1] === 0) {\n    return inBounds(p1, p2, p) ? p : null;\n  }\n\n  const qx = (k * p[1] + p[0] - k * b) / (k * k + 1);\n  const qy = k * qx + b;\n\n  return inBounds(p1, p2, [qx, qy]) ? [qx, qy] : null;\n}\n\nexport function getFeatureCoordinates(feature: Feature) {\n  const coordinates = feature && feature.geometry && feature.geometry.coordinates;\n  if (!coordinates) {\n    return null;\n  }\n\n  const isPolygonal = feature.geometry.type === GEOJSON_TYPE.POLYGON;\n  return isPolygonal ? coordinates[0] : coordinates;\n}\n\nexport function updateRectanglePosition(\n  feature: Feature,\n  editHandleIndex: number,\n  mapCoords: Position\n) {\n  const coordinates = getFeatureCoordinates(feature);\n  if (!coordinates) {\n    return null;\n  }\n\n  const points = coordinates.slice(0, 4);\n  points[editHandleIndex % 4] = mapCoords;\n\n  /*\n  *   p0.x, p0.y (p0) ------ p2.x, p0.y (p1)\n  *       |                      |\n  *       |                      |\n  *   p0.x, p2.y (p3) ----- p2.x, p2.y (p2)\n  */\n  const p0 = points[(editHandleIndex + 2) % 4];\n  const p2 = points[editHandleIndex % 4];\n  points[(editHandleIndex + 1) % 4] = [p2[0], p0[1]];\n  points[(editHandleIndex + 3) % 4] = [p0[0], p2[1]];\n\n  return feature.geometry.type === GEOJSON_TYPE.POLYGON ? [[...points, points[0]]] : points;\n}\n\nfunction inBounds(p1: Position, p2: Position, p: Position) {\n  const bounds = [\n    Math.min(p1[0], p2[0]),\n    Math.max(p1[0], p2[0]),\n    Math.min(p1[1], p2[1]),\n    Math.max(p1[1], p2[1])\n  ];\n\n  return p[0] >= bounds[0] && p[0] <= bounds[1] && p[1] >= bounds[2] && p[1] <= bounds[3];\n}\n"]}