@pansy/react-mapbox-gl
Version:
🌍 基于 Mapbox GL 封装的 React 组件库
162 lines (160 loc) • 6.22 kB
JavaScript
var __create = Object.create;
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/components/MarkerCluster/MarkerCluster.tsx
var MarkerCluster_exports = {};
__export(MarkerCluster_exports, {
MarkerCluster: () => MarkerCluster
});
module.exports = __toCommonJS(MarkerCluster_exports);
var import_react = __toESM(require("react"));
var import_core = require("@rcuse/core");
var import_mapbox_gl = require("mapbox-gl");
var import_supercluster = __toESM(require("supercluster"));
var import_bbox = __toESM(require("@turf/bbox"));
var import_helpers = require("@turf/helpers");
var import_Marker = require("../Marker");
var import_useMap = require("../../hooks/useMap");
var import_config = require("./config");
function InternalMarkerCluster(props, ref) {
const {
cluster,
render,
renderCluster,
data = [],
zoomOnClick,
zoomOnClickPadding = 20,
onClick,
onClusterClick
} = props;
const { map } = (0, import_useMap.useMap)();
const [list, setList] = (0, import_react.useState)([]);
const supercluster = (0, import_react.useMemo)(() => {
return new import_supercluster.default(__spreadValues(__spreadValues({}, import_config.defaultSuperclusterOptions), cluster));
}, []);
const getMapBoundary = () => {
const bounds = map.getBounds();
const zoom = map.getZoom();
return [
// @ts-expect-error
[bounds.getWest(), bounds.getSouth(), bounds.getEast(), bounds.getNorth()],
Math.round(zoom)
];
};
const handleChangeBoundary = (0, import_react.useCallback)(
(0, import_core.debounce)({ delay: 500 }, () => {
const mapBoundary = getMapBoundary();
const result = supercluster.getClusters(...mapBoundary);
setList(
result.map((item) => {
return __spreadProps(__spreadValues({}, item), {
id: item.id || (0, import_core.uuid)()
});
})
);
}),
[]
);
(0, import_react.useEffect)(() => {
if (map) {
map.on("zoom", handleChangeBoundary);
map.on("move", handleChangeBoundary);
map.on("resize", handleChangeBoundary);
return () => {
map.off("zoom", handleChangeBoundary);
map.off("move", handleChangeBoundary);
map.off("resize", handleChangeBoundary);
};
}
return void 0;
}, [map]);
(0, import_react.useEffect)(() => {
if (data) {
supercluster.load(data);
handleChangeBoundary();
}
}, [data]);
(0, import_react.useImperativeHandle)(ref, () => supercluster, []);
const handleClusterMarkerClick = (data2) => {
const { properties } = data2;
if (!(properties == null ? void 0 : properties.cluster))
return;
const children = supercluster.getLeaves(properties.cluster_id, Number.POSITIVE_INFINITY);
const childrenBbox = (0, import_bbox.default)((0, import_helpers.featureCollection)(children));
map.fitBounds(import_mapbox_gl.LngLatBounds.convert(childrenBbox), {
padding: zoomOnClickPadding
});
};
return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, list.map((item) => {
const { geometry, properties } = item;
const { point_count, cluster: cluster2, cluster_id } = properties;
if (cluster2) {
return /* @__PURE__ */ import_react.default.createElement(
import_Marker.Marker,
{
key: item.id,
lngLat: geometry.coordinates,
onClick: () => {
onClusterClick == null ? void 0 : onClusterClick(point_count, cluster_id);
if (zoomOnClick)
handleClusterMarkerClick(item);
}
},
(0, import_core.isFunction)(renderCluster) ? renderCluster(point_count, cluster_id) : renderCluster
);
}
return /* @__PURE__ */ import_react.default.createElement(
import_Marker.Marker,
{
key: item.id,
lngLat: geometry.coordinates,
onClick: () => {
onClick == null ? void 0 : onClick(item);
}
},
(0, import_core.isFunction)(render) ? render(item) : render
);
}));
}
var MarkerCluster = (0, import_react.forwardRef)(InternalMarkerCluster);