@mdworld/react-simple-maps
Version:
An svg map chart component built with and for React
1,097 lines (966 loc) • 36.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var PropTypes = require('prop-types');
var d3Geo = require('d3-geo');
var topojsonClient = require('topojson-client');
var d3Zoom = require('d3-zoom');
var d3Selection = require('d3-selection');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
function _interopNamespace(e) {
if (e && e.__esModule) return e;
var n = Object.create(null);
if (e) {
Object.keys(e).forEach(function (k) {
if (k !== 'default') {
var d = Object.getOwnPropertyDescriptor(e, k);
Object.defineProperty(n, k, d.get ? d : {
enumerable: true,
get: function () { return e[k]; }
});
}
});
}
n["default"] = e;
return Object.freeze(n);
}
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
var d3Geo__namespace = /*#__PURE__*/_interopNamespace(d3Geo);
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
enumerableOnly && (symbols = symbols.filter(function (sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
})), keys.push.apply(keys, symbols);
}
return keys;
}
function _objectSpread2(target) {
for (var i = 1; i < arguments.length; i++) {
var source = null != arguments[i] ? arguments[i] : {};
i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {
_defineProperty(target, key, source[key]);
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
return target;
}
function _typeof(obj) {
"@babel/helpers - typeof";
return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
return typeof obj;
} : function (obj) {
return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
}, _typeof(obj);
}
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
function _extends() {
_extends = Object.assign ? Object.assign.bind() : function (target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i];
for (var key in source) {
if (Object.prototype.hasOwnProperty.call(source, key)) {
target[key] = source[key];
}
}
}
return target;
};
return _extends.apply(this, arguments);
}
function _objectWithoutPropertiesLoose(source, excluded) {
if (source == null) return {};
var target = {};
var sourceKeys = Object.keys(source);
var key, i;
for (i = 0; i < sourceKeys.length; i++) {
key = sourceKeys[i];
if (excluded.indexOf(key) >= 0) continue;
target[key] = source[key];
}
return target;
}
function _objectWithoutProperties(source, excluded) {
if (source == null) return {};
var target = _objectWithoutPropertiesLoose(source, excluded);
var key, i;
if (Object.getOwnPropertySymbols) {
var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
for (i = 0; i < sourceSymbolKeys.length; i++) {
key = sourceSymbolKeys[i];
if (excluded.indexOf(key) >= 0) continue;
if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
target[key] = source[key];
}
}
return target;
}
function _slicedToArray(arr, i) {
return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
}
function _arrayWithHoles(arr) {
if (Array.isArray(arr)) return arr;
}
function _iterableToArrayLimit(arr, i) {
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
if (_i == null) return;
var _arr = [];
var _n = true;
var _d = false;
var _s, _e;
try {
for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
_arr.push(_s.value);
if (i && _arr.length === i) break;
}
} catch (err) {
_d = true;
_e = err;
} finally {
try {
if (!_n && _i["return"] != null) _i["return"]();
} finally {
if (_d) throw _e;
}
}
return _arr;
}
function _unsupportedIterableToArray(o, minLen) {
if (!o) return;
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor) n = o.constructor.name;
if (n === "Map" || n === "Set") return Array.from(o);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
}
function _arrayLikeToArray(arr, len) {
if (len == null || len > arr.length) len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
return arr2;
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
var _excluded$a = ["width", "height", "projection", "projectionConfig"];
var geoPath = d3Geo__namespace.geoPath,
projections = _objectWithoutProperties(d3Geo__namespace, ["geoPath"]);
var MapContext = React.createContext();
var makeProjection = function makeProjection(_ref) {
var _ref$projectionConfig = _ref.projectionConfig,
projectionConfig = _ref$projectionConfig === void 0 ? {} : _ref$projectionConfig,
_ref$projection = _ref.projection,
projection = _ref$projection === void 0 ? "geoEqualEarth" : _ref$projection,
_ref$width = _ref.width,
width = _ref$width === void 0 ? 800 : _ref$width,
_ref$height = _ref.height,
height = _ref$height === void 0 ? 600 : _ref$height;
var isFunc = typeof projection === "function";
if (isFunc) return projection;
var proj = projections[projection]().translate([width / 2, height / 2]);
var supported = [proj.center ? "center" : null, proj.rotate ? "rotate" : null, proj.scale ? "scale" : null, proj.parallels ? "parallels" : null];
supported.forEach(function (d) {
if (!d) return;
proj = proj[d](projectionConfig[d] || proj[d]());
});
return proj;
};
var MapProvider = function MapProvider(_ref2) {
var width = _ref2.width,
height = _ref2.height,
projection = _ref2.projection,
projectionConfig = _ref2.projectionConfig,
restProps = _objectWithoutProperties(_ref2, _excluded$a);
var _ref3 = projectionConfig.center || [],
_ref4 = _slicedToArray(_ref3, 2),
cx = _ref4[0],
cy = _ref4[1];
var _ref5 = projectionConfig.rotate || [],
_ref6 = _slicedToArray(_ref5, 3),
rx = _ref6[0],
ry = _ref6[1],
rz = _ref6[2];
var _ref7 = projectionConfig.parallels || [],
_ref8 = _slicedToArray(_ref7, 2),
p1 = _ref8[0],
p2 = _ref8[1];
var s = projectionConfig.scale || null;
var projMemo = React.useMemo(function () {
return makeProjection({
projectionConfig: {
center: cx || cx === 0 || cy || cy === 0 ? [cx, cy] : null,
rotate: rx || rx === 0 || ry || ry === 0 ? [rx, ry, rz] : null,
parallels: p1 || p1 === 0 || p2 || p2 === 0 ? [p1, p2] : null,
scale: s
},
projection: projection,
width: width,
height: height
});
}, [width, height, projection, cx, cy, rx, ry, rz, p1, p2, s]);
var proj = React.useCallback(projMemo, [projMemo]);
var value = React.useMemo(function () {
return {
width: width,
height: height,
projection: proj,
path: geoPath().projection(proj)
};
}, [width, height, proj]);
return /*#__PURE__*/React__default["default"].createElement(MapContext.Provider, _extends({
value: value
}, restProps));
};
MapProvider.propTypes = {
width: PropTypes__default["default"].number,
height: PropTypes__default["default"].number,
projection: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].func]),
projectionConfig: PropTypes__default["default"].object
};
var useMapContext = function useMapContext() {
return React.useContext(MapContext);
};
var _excluded$9 = ["width", "height", "projection", "projectionConfig", "className"];
var ComposableMap = React.forwardRef(function (_ref, ref) {
var _ref$width = _ref.width,
width = _ref$width === void 0 ? 800 : _ref$width,
_ref$height = _ref.height,
height = _ref$height === void 0 ? 600 : _ref$height,
_ref$projection = _ref.projection,
projection = _ref$projection === void 0 ? "geoEqualEarth" : _ref$projection,
_ref$projectionConfig = _ref.projectionConfig,
projectionConfig = _ref$projectionConfig === void 0 ? {} : _ref$projectionConfig,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$9);
return /*#__PURE__*/React__default["default"].createElement(MapProvider, {
width: width,
height: height,
projection: projection,
projectionConfig: projectionConfig
}, /*#__PURE__*/React__default["default"].createElement("svg", _extends({
ref: ref,
viewBox: "0 0 ".concat(width, " ").concat(height),
className: "rsm-svg ".concat(className)
}, restProps)));
});
ComposableMap.displayName = "ComposableMap";
ComposableMap.propTypes = {
width: PropTypes__default["default"].number,
height: PropTypes__default["default"].number,
projection: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].func]),
projectionConfig: PropTypes__default["default"].object,
className: PropTypes__default["default"].string
};
function getCoords(w, h, t) {
var xOffset = (w * t.k - w) / 2;
var yOffset = (h * t.k - h) / 2;
return [w / 2 - (xOffset + t.x) / t.k, h / 2 - (yOffset + t.y) / t.k];
}
function fetchGeographies(url) {
return fetch(url).then(function (res) {
if (!res.ok) {
throw Error(res.statusText);
}
return res.json();
})["catch"](function (error) {
console.log("There was a problem when fetching the data: ", error);
});
}
function getFeatures(geographies, parseGeographies) {
var isTopojson = geographies.type === "Topology";
if (!isTopojson) {
return parseGeographies ? parseGeographies(geographies.features || geographies) : geographies.features || geographies;
}
var feats = topojsonClient.feature(geographies, geographies.objects[Object.keys(geographies.objects)[0]]).features;
return parseGeographies ? parseGeographies(feats) : feats;
}
function getMesh(geographies) {
var isTopojson = geographies.type === "Topology";
if (!isTopojson) return null;
var outline = topojsonClient.mesh(geographies, geographies.objects[Object.keys(geographies.objects)[0]], function (a, b) {
return a === b;
});
var borders = topojsonClient.mesh(geographies, geographies.objects[Object.keys(geographies.objects)[0]], function (a, b) {
return a !== b;
});
return {
outline: outline,
borders: borders
};
}
function prepareMesh(outline, borders, path) {
return outline && borders ? {
outline: _objectSpread2(_objectSpread2({}, outline), {}, {
rsmKey: "outline",
svgPath: path(outline)
}),
borders: _objectSpread2(_objectSpread2({}, borders), {}, {
rsmKey: "borders",
svgPath: path(borders)
})
} : {};
}
function prepareFeatures(geographies, path) {
return geographies ? geographies.map(function (d, i) {
return _objectSpread2(_objectSpread2({}, d), {}, {
rsmKey: "geo-".concat(i),
svgPath: path(d)
});
}) : [];
}
function createConnectorPath() {
var dx = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 30;
var dy = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
var curve = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0.5;
var curvature = Array.isArray(curve) ? curve : [curve, curve];
var curveX = dx / 2 * curvature[0];
var curveY = dy / 2 * curvature[1];
return "M".concat(0, ",", 0, " Q", -dx / 2 - curveX, ",").concat(-dy / 2 + curveY, " ").concat(-dx, ",").concat(-dy);
}
function isString(geo) {
return typeof geo === "string";
}
function useGeographies(_ref) {
var geography = _ref.geography,
parseGeographies = _ref.parseGeographies;
var _useContext = React.useContext(MapContext),
path = _useContext.path;
var _useState = React.useState({}),
_useState2 = _slicedToArray(_useState, 2),
output = _useState2[0],
setOutput = _useState2[1];
React.useEffect(function () {
if ((typeof window === "undefined" ? "undefined" : _typeof(window)) === "undefined") return;
if (!geography) return;
if (isString(geography)) {
fetchGeographies(geography).then(function (geos) {
if (geos) {
setOutput({
geographies: getFeatures(geos, parseGeographies),
mesh: getMesh(geos)
});
}
});
} else {
setOutput({
geographies: getFeatures(geography, parseGeographies),
mesh: getMesh(geography)
});
}
}, [geography, parseGeographies]);
var _useMemo = React.useMemo(function () {
var mesh = output.mesh || {};
var preparedMesh = prepareMesh(mesh.outline, mesh.borders, path);
return {
geographies: prepareFeatures(output.geographies, path),
outline: preparedMesh.outline,
borders: preparedMesh.borders
};
}, [output, path]),
geographies = _useMemo.geographies,
outline = _useMemo.outline,
borders = _useMemo.borders;
return {
geographies: geographies,
outline: outline,
borders: borders
};
}
var _excluded$8 = ["geography", "children", "parseGeographies", "className"];
var Geographies = React.forwardRef(function (_ref, ref) {
var geography = _ref.geography,
children = _ref.children,
parseGeographies = _ref.parseGeographies,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$8);
var _useContext = React.useContext(MapContext),
path = _useContext.path,
projection = _useContext.projection;
var _useGeographies = useGeographies({
geography: geography,
parseGeographies: parseGeographies
}),
geographies = _useGeographies.geographies,
outline = _useGeographies.outline,
borders = _useGeographies.borders;
return /*#__PURE__*/React__default["default"].createElement("g", _extends({
ref: ref,
className: "rsm-geographies ".concat(className)
}, restProps), geographies && geographies.length > 0 && children({
geographies: geographies,
outline: outline,
borders: borders,
path: path,
projection: projection
}));
});
Geographies.displayName = "Geographies";
Geographies.propTypes = {
geography: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].object, PropTypes__default["default"].array]),
children: PropTypes__default["default"].func,
parseGeographies: PropTypes__default["default"].func,
className: PropTypes__default["default"].string
};
var _excluded$7 = ["geography", "onMouseEnter", "onMouseLeave", "onMouseDown", "onMouseUp", "onFocus", "onBlur", "style", "className"];
var Geography = React.forwardRef(function (_ref, ref) {
var geography = _ref.geography,
onMouseEnter = _ref.onMouseEnter,
onMouseLeave = _ref.onMouseLeave,
onMouseDown = _ref.onMouseDown,
onMouseUp = _ref.onMouseUp,
onFocus = _ref.onFocus,
onBlur = _ref.onBlur,
_ref$style = _ref.style,
style = _ref$style === void 0 ? {} : _ref$style,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$7);
var _useState = React.useState(false),
_useState2 = _slicedToArray(_useState, 2),
isPressed = _useState2[0],
setPressed = _useState2[1];
var _useState3 = React.useState(false),
_useState4 = _slicedToArray(_useState3, 2),
isFocused = _useState4[0],
setFocus = _useState4[1];
function handleMouseEnter(evt) {
setFocus(true);
if (onMouseEnter) onMouseEnter(evt);
}
function handleMouseLeave(evt) {
setFocus(false);
if (isPressed) setPressed(false);
if (onMouseLeave) onMouseLeave(evt);
}
function handleFocus(evt) {
setFocus(true);
if (onFocus) onFocus(evt);
}
function handleBlur(evt) {
setFocus(false);
if (isPressed) setPressed(false);
if (onBlur) onBlur(evt);
}
function handleMouseDown(evt) {
setPressed(true);
if (onMouseDown) onMouseDown(evt);
}
function handleMouseUp(evt) {
setPressed(false);
if (onMouseUp) onMouseUp(evt);
}
return /*#__PURE__*/React__default["default"].createElement("path", _extends({
ref: ref,
tabIndex: "0",
className: "rsm-geography ".concat(className),
d: geography.svgPath,
onMouseEnter: handleMouseEnter,
onMouseLeave: handleMouseLeave,
onFocus: handleFocus,
onBlur: handleBlur,
onMouseDown: handleMouseDown,
onMouseUp: handleMouseUp,
style: style[isPressed || isFocused ? isPressed ? "pressed" : "hover" : "default"]
}, restProps));
});
Geography.displayName = "Geography";
Geography.propTypes = {
geography: PropTypes__default["default"].object,
onMouseEnter: PropTypes__default["default"].func,
onMouseLeave: PropTypes__default["default"].func,
onMouseDown: PropTypes__default["default"].func,
onMouseUp: PropTypes__default["default"].func,
onFocus: PropTypes__default["default"].func,
onBlur: PropTypes__default["default"].func,
style: PropTypes__default["default"].object,
className: PropTypes__default["default"].string
};
var Geography$1 = React.memo(Geography);
var _excluded$6 = ["fill", "stroke", "step", "className"];
var Graticule = React.forwardRef(function (_ref, ref) {
var _ref$fill = _ref.fill,
fill = _ref$fill === void 0 ? "transparent" : _ref$fill,
_ref$stroke = _ref.stroke,
stroke = _ref$stroke === void 0 ? "currentcolor" : _ref$stroke,
_ref$step = _ref.step,
step = _ref$step === void 0 ? [10, 10] : _ref$step,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$6);
var _useContext = React.useContext(MapContext),
path = _useContext.path;
return /*#__PURE__*/React__default["default"].createElement("path", _extends({
ref: ref,
d: path(d3Geo.geoGraticule().step(step)()),
fill: fill,
stroke: stroke,
className: "rsm-graticule ".concat(className)
}, restProps));
});
Graticule.displayName = "Graticule";
Graticule.propTypes = {
fill: PropTypes__default["default"].string,
stroke: PropTypes__default["default"].string,
step: PropTypes__default["default"].array,
className: PropTypes__default["default"].string
};
var Graticule$1 = React.memo(Graticule);
var _excluded$5 = ["value"];
var ZoomPanContext = React.createContext();
var defaultValue = {
x: 0,
y: 0,
k: 1,
transformString: "translate(0 0) scale(1)"
};
var ZoomPanProvider = function ZoomPanProvider(_ref) {
var _ref$value = _ref.value,
value = _ref$value === void 0 ? defaultValue : _ref$value,
restProps = _objectWithoutProperties(_ref, _excluded$5);
return /*#__PURE__*/React__default["default"].createElement(ZoomPanContext.Provider, _extends({
value: value
}, restProps));
};
ZoomPanProvider.propTypes = {
x: PropTypes__default["default"].number,
y: PropTypes__default["default"].number,
k: PropTypes__default["default"].number,
transformString: PropTypes__default["default"].string
};
var useZoomPanContext = function useZoomPanContext() {
return React.useContext(ZoomPanContext);
};
function useZoomPan(_ref) {
var center = _ref.center,
filterZoomEvent = _ref.filterZoomEvent,
onMoveStart = _ref.onMoveStart,
onMoveEnd = _ref.onMoveEnd,
onMove = _ref.onMove,
_ref$translateExtent = _ref.translateExtent,
translateExtent = _ref$translateExtent === void 0 ? [[-Infinity, -Infinity], [Infinity, Infinity]] : _ref$translateExtent,
_ref$scaleExtent = _ref.scaleExtent,
scaleExtent = _ref$scaleExtent === void 0 ? [1, 8] : _ref$scaleExtent,
_ref$zoom = _ref.zoom,
zoom = _ref$zoom === void 0 ? 1 : _ref$zoom;
var _useContext = React.useContext(MapContext),
width = _useContext.width,
height = _useContext.height,
projection = _useContext.projection;
var _center = _slicedToArray(center, 2),
lon = _center[0],
lat = _center[1];
var _useState = React.useState({
x: 0,
y: 0,
k: 1
}),
_useState2 = _slicedToArray(_useState, 2),
position = _useState2[0],
setPosition = _useState2[1];
var lastPosition = React.useRef({
x: 0,
y: 0,
k: 1
});
var mapRef = React.useRef();
var zoomRef = React.useRef();
var bypassEvents = React.useRef(false);
var _translateExtent = _slicedToArray(translateExtent, 2),
a = _translateExtent[0],
b = _translateExtent[1];
var _a = _slicedToArray(a, 2),
a1 = _a[0],
a2 = _a[1];
var _b = _slicedToArray(b, 2),
b1 = _b[0],
b2 = _b[1];
var _scaleExtent = _slicedToArray(scaleExtent, 2),
minZoom = _scaleExtent[0],
maxZoom = _scaleExtent[1];
React.useEffect(function () {
var svg = d3Selection.select(mapRef.current);
function handleZoomStart(d3Event) {
if (!onMoveStart || bypassEvents.current) return;
onMoveStart({
coordinates: projection.invert(getCoords(width, height, d3Event.transform)),
zoom: d3Event.transform.k
}, d3Event);
}
function handleZoom(d3Event) {
if (bypassEvents.current) return;
var transform = d3Event.transform,
sourceEvent = d3Event.sourceEvent;
setPosition({
x: transform.x,
y: transform.y,
k: transform.k,
dragging: sourceEvent
});
if (!onMove) return;
onMove({
x: transform.x,
y: transform.y,
zoom: transform.k,
dragging: sourceEvent
}, d3Event);
}
function handleZoomEnd(d3Event) {
if (bypassEvents.current) {
bypassEvents.current = false;
return;
}
var _projection$invert = projection.invert(getCoords(width, height, d3Event.transform)),
_projection$invert2 = _slicedToArray(_projection$invert, 2),
x = _projection$invert2[0],
y = _projection$invert2[1];
lastPosition.current = {
x: x,
y: y,
k: d3Event.transform.k
};
if (!onMoveEnd) return;
onMoveEnd({
coordinates: [x, y],
zoom: d3Event.transform.k
}, d3Event);
}
function filterFunc(d3Event) {
if (filterZoomEvent) {
return filterZoomEvent(d3Event);
}
return d3Event ? !d3Event.ctrlKey && !d3Event.button : false;
}
var zoom = d3Zoom.zoom().filter(filterFunc).scaleExtent([minZoom, maxZoom]).translateExtent([[a1, a2], [b1, b2]]).on("start", handleZoomStart).on("zoom", handleZoom).on("end", handleZoomEnd);
zoomRef.current = zoom;
svg.call(zoom);
}, [width, height, a1, a2, b1, b2, minZoom, maxZoom, projection, onMoveStart, onMove, onMoveEnd, filterZoomEvent]);
React.useEffect(function () {
if (lon === lastPosition.current.x && lat === lastPosition.current.y && zoom === lastPosition.current.k) return;
var coords = projection([lon, lat]);
var x = coords[0] * zoom;
var y = coords[1] * zoom;
var svg = d3Selection.select(mapRef.current);
bypassEvents.current = true;
svg.call(zoomRef.current.transform, d3Zoom.zoomIdentity.translate(width / 2 - x, height / 2 - y).scale(zoom));
setPosition({
x: width / 2 - x,
y: height / 2 - y,
k: zoom
});
lastPosition.current = {
x: lon,
y: lat,
k: zoom
};
}, [lon, lat, zoom, width, height, projection]);
return {
mapRef: mapRef,
position: position,
transformString: "translate(".concat(position.x, " ").concat(position.y, ") scale(").concat(position.k, ")")
};
}
var _excluded$4 = ["center", "zoom", "minZoom", "maxZoom", "translateExtent", "filterZoomEvent", "onMoveStart", "onMove", "onMoveEnd", "className"];
var ZoomableGroup = React.forwardRef(function (_ref, ref) {
var _ref$center = _ref.center,
center = _ref$center === void 0 ? [0, 0] : _ref$center,
_ref$zoom = _ref.zoom,
zoom = _ref$zoom === void 0 ? 1 : _ref$zoom,
_ref$minZoom = _ref.minZoom,
minZoom = _ref$minZoom === void 0 ? 1 : _ref$minZoom,
_ref$maxZoom = _ref.maxZoom,
maxZoom = _ref$maxZoom === void 0 ? 8 : _ref$maxZoom,
translateExtent = _ref.translateExtent,
filterZoomEvent = _ref.filterZoomEvent,
onMoveStart = _ref.onMoveStart,
onMove = _ref.onMove,
onMoveEnd = _ref.onMoveEnd,
className = _ref.className,
restProps = _objectWithoutProperties(_ref, _excluded$4);
var _useContext = React.useContext(MapContext),
width = _useContext.width,
height = _useContext.height;
var _useZoomPan = useZoomPan({
center: center,
filterZoomEvent: filterZoomEvent,
onMoveStart: onMoveStart,
onMove: onMove,
onMoveEnd: onMoveEnd,
scaleExtent: [minZoom, maxZoom],
translateExtent: translateExtent,
zoom: zoom
}),
mapRef = _useZoomPan.mapRef,
transformString = _useZoomPan.transformString,
position = _useZoomPan.position;
return /*#__PURE__*/React__default["default"].createElement(ZoomPanProvider, {
value: {
x: position.x,
y: position.y,
k: position.k,
transformString: transformString
}
}, /*#__PURE__*/React__default["default"].createElement("g", {
ref: mapRef
}, /*#__PURE__*/React__default["default"].createElement("rect", {
width: width,
height: height,
fill: "transparent"
}), /*#__PURE__*/React__default["default"].createElement("g", _extends({
ref: ref,
transform: transformString,
className: "rsm-zoomable-group ".concat(className)
}, restProps))));
});
ZoomableGroup.displayName = "ZoomableGroup";
ZoomableGroup.propTypes = {
center: PropTypes__default["default"].array,
zoom: PropTypes__default["default"].number,
minZoom: PropTypes__default["default"].number,
maxZoom: PropTypes__default["default"].number,
translateExtent: PropTypes__default["default"].arrayOf(PropTypes__default["default"].array),
onMoveStart: PropTypes__default["default"].func,
onMove: PropTypes__default["default"].func,
onMoveEnd: PropTypes__default["default"].func,
className: PropTypes__default["default"].string
};
var _excluded$3 = ["id", "fill", "stroke", "strokeWidth", "className"];
var Sphere = React.forwardRef(function (_ref, ref) {
var _ref$id = _ref.id,
id = _ref$id === void 0 ? "rsm-sphere" : _ref$id,
_ref$fill = _ref.fill,
fill = _ref$fill === void 0 ? "transparent" : _ref$fill,
_ref$stroke = _ref.stroke,
stroke = _ref$stroke === void 0 ? "currentcolor" : _ref$stroke,
_ref$strokeWidth = _ref.strokeWidth,
strokeWidth = _ref$strokeWidth === void 0 ? 0.5 : _ref$strokeWidth,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$3);
var _useContext = React.useContext(MapContext),
path = _useContext.path;
var spherePath = React.useMemo(function () {
return path({
type: "Sphere"
});
}, [path]);
return /*#__PURE__*/React__default["default"].createElement(React.Fragment, null, /*#__PURE__*/React__default["default"].createElement("defs", null, /*#__PURE__*/React__default["default"].createElement("clipPath", {
id: id
}, /*#__PURE__*/React__default["default"].createElement("path", {
d: spherePath
}))), /*#__PURE__*/React__default["default"].createElement("path", _extends({
ref: ref,
d: spherePath,
fill: fill,
stroke: stroke,
strokeWidth: strokeWidth,
style: {
pointerEvents: "none"
},
className: "rsm-sphere ".concat(className)
}, restProps)));
});
Sphere.displayName = "Sphere";
Sphere.propTypes = {
id: PropTypes__default["default"].string,
fill: PropTypes__default["default"].string,
stroke: PropTypes__default["default"].string,
strokeWidth: PropTypes__default["default"].number,
className: PropTypes__default["default"].string
};
var Sphere$1 = React.memo(Sphere);
var _excluded$2 = ["coordinates", "children", "onMouseEnter", "onMouseLeave", "onMouseDown", "onMouseUp", "onFocus", "onBlur", "style", "className"];
var Marker = React.forwardRef(function (_ref, ref) {
var coordinates = _ref.coordinates,
children = _ref.children,
onMouseEnter = _ref.onMouseEnter,
onMouseLeave = _ref.onMouseLeave,
onMouseDown = _ref.onMouseDown,
onMouseUp = _ref.onMouseUp,
onFocus = _ref.onFocus,
onBlur = _ref.onBlur,
_ref$style = _ref.style,
style = _ref$style === void 0 ? {} : _ref$style,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$2);
var _useContext = React.useContext(MapContext),
projection = _useContext.projection;
var _useState = React.useState(false),
_useState2 = _slicedToArray(_useState, 2),
isPressed = _useState2[0],
setPressed = _useState2[1];
var _useState3 = React.useState(false),
_useState4 = _slicedToArray(_useState3, 2),
isFocused = _useState4[0],
setFocus = _useState4[1];
var _projection = projection(coordinates),
_projection2 = _slicedToArray(_projection, 2),
x = _projection2[0],
y = _projection2[1];
function handleMouseEnter(evt) {
setFocus(true);
if (onMouseEnter) onMouseEnter(evt);
}
function handleMouseLeave(evt) {
setFocus(false);
if (isPressed) setPressed(false);
if (onMouseLeave) onMouseLeave(evt);
}
function handleFocus(evt) {
setFocus(true);
if (onFocus) onFocus(evt);
}
function handleBlur(evt) {
setFocus(false);
if (isPressed) setPressed(false);
if (onBlur) onBlur(evt);
}
function handleMouseDown(evt) {
setPressed(true);
if (onMouseDown) onMouseDown(evt);
}
function handleMouseUp(evt) {
setPressed(false);
if (onMouseUp) onMouseUp(evt);
}
return /*#__PURE__*/React__default["default"].createElement("g", _extends({
ref: ref,
transform: "translate(".concat(x, ", ").concat(y, ")"),
className: "rsm-marker ".concat(className),
onMouseEnter: handleMouseEnter,
onMouseLeave: handleMouseLeave,
onFocus: handleFocus,
onBlur: handleBlur,
onMouseDown: handleMouseDown,
onMouseUp: handleMouseUp,
style: style[isPressed || isFocused ? isPressed ? "pressed" : "hover" : "default"]
}, restProps), children);
});
Marker.displayName = "Marker";
Marker.propTypes = {
coordinates: PropTypes__default["default"].array,
children: PropTypes__default["default"].oneOfType([PropTypes__default["default"].node, PropTypes__default["default"].arrayOf(PropTypes__default["default"].node)]),
onMouseEnter: PropTypes__default["default"].func,
onMouseLeave: PropTypes__default["default"].func,
onMouseDown: PropTypes__default["default"].func,
onMouseUp: PropTypes__default["default"].func,
onFocus: PropTypes__default["default"].func,
onBlur: PropTypes__default["default"].func,
style: PropTypes__default["default"].object,
className: PropTypes__default["default"].string
};
var _excluded$1 = ["from", "to", "coordinates", "stroke", "strokeWidth", "fill", "className"];
var Line = React.forwardRef(function (_ref, ref) {
var _ref$from = _ref.from,
from = _ref$from === void 0 ? [0, 0] : _ref$from,
_ref$to = _ref.to,
to = _ref$to === void 0 ? [0, 0] : _ref$to,
coordinates = _ref.coordinates,
_ref$stroke = _ref.stroke,
stroke = _ref$stroke === void 0 ? "currentcolor" : _ref$stroke,
_ref$strokeWidth = _ref.strokeWidth,
strokeWidth = _ref$strokeWidth === void 0 ? 3 : _ref$strokeWidth,
_ref$fill = _ref.fill,
fill = _ref$fill === void 0 ? "transparent" : _ref$fill,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded$1);
var _useContext = React.useContext(MapContext),
path = _useContext.path;
var lineData = {
type: "LineString",
coordinates: coordinates || [from, to]
};
return /*#__PURE__*/React__default["default"].createElement("path", _extends({
ref: ref,
d: path(lineData),
className: "rsm-line ".concat(className),
stroke: stroke,
strokeWidth: strokeWidth,
fill: fill
}, restProps));
});
Line.displayName = "Line";
Line.propTypes = {
from: PropTypes__default["default"].array,
to: PropTypes__default["default"].array,
coordinates: PropTypes__default["default"].array,
stroke: PropTypes__default["default"].string,
strokeWidth: PropTypes__default["default"].number,
fill: PropTypes__default["default"].string,
className: PropTypes__default["default"].string
};
var _excluded = ["subject", "children", "connectorProps", "dx", "dy", "curve", "className"];
var Annotation = React.forwardRef(function (_ref, ref) {
var subject = _ref.subject,
children = _ref.children,
connectorProps = _ref.connectorProps,
_ref$dx = _ref.dx,
dx = _ref$dx === void 0 ? 30 : _ref$dx,
_ref$dy = _ref.dy,
dy = _ref$dy === void 0 ? 30 : _ref$dy,
_ref$curve = _ref.curve,
curve = _ref$curve === void 0 ? 0 : _ref$curve,
_ref$className = _ref.className,
className = _ref$className === void 0 ? "" : _ref$className,
restProps = _objectWithoutProperties(_ref, _excluded);
var _useContext = React.useContext(MapContext),
projection = _useContext.projection;
var _projection = projection(subject),
_projection2 = _slicedToArray(_projection, 2),
x = _projection2[0],
y = _projection2[1];
var connectorPath = createConnectorPath(dx, dy, curve);
return /*#__PURE__*/React__default["default"].createElement("g", _extends({
ref: ref,
transform: "translate(".concat(x + dx, ", ").concat(y + dy, ")"),
className: "rsm-annotation ".concat(className)
}, restProps), /*#__PURE__*/React__default["default"].createElement("path", _extends({
d: connectorPath,
fill: "transparent",
stroke: "#000"
}, connectorProps)), children);
});
Annotation.displayName = "Annotation";
Annotation.propTypes = {
subject: PropTypes__default["default"].array,
children: PropTypes__default["default"].oneOfType([PropTypes__default["default"].node, PropTypes__default["default"].arrayOf(PropTypes__default["default"].node)]),
dx: PropTypes__default["default"].number,
dy: PropTypes__default["default"].number,
curve: PropTypes__default["default"].number,
connectorProps: PropTypes__default["default"].object,
className: PropTypes__default["default"].string
};
exports.Annotation = Annotation;
exports.ComposableMap = ComposableMap;
exports.Geographies = Geographies;
exports.Geography = Geography$1;
exports.Graticule = Graticule$1;
exports.Line = Line;
exports.MapContext = MapContext;
exports.MapProvider = MapProvider;
exports.Marker = Marker;
exports.Sphere = Sphere$1;
exports.ZoomPanContext = ZoomPanContext;
exports.ZoomPanProvider = ZoomPanProvider;
exports.ZoomableGroup = ZoomableGroup;
exports.useGeographies = useGeographies;
exports.useMapContext = useMapContext;
exports.useZoomPan = useZoomPan;
exports.useZoomPanContext = useZoomPanContext;