UNPKG

@pansy/react-mapbox-gl

Version:

🌍 基于 Mapbox GL 封装的 React 组件库

117 lines (115 loc) 4.46 kB
var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; 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/Marker/marker.tsx var marker_exports = {}; __export(marker_exports, { Marker: () => Marker }); module.exports = __toCommonJS(marker_exports); var import_react = __toESM(require("react")); var import_mapbox_gl = __toESM(require("mapbox-gl")); var import_core = require("@rcuse/core"); var import_useMap = require("../../hooks/useMap"); var import_usePropsReactive = require("../../hooks/usePropsReactive"); var import_useEvents = require("../../hooks/useEvents"); var import_config = require("./config"); var import_constant = require("./constant"); var Marker = import_react.default.forwardRef((props, ref) => { const { map } = (0, import_useMap.useMap)(); const { Portal, container } = (0, import_core.usePortal)(); const [marker, setMarker, getMarker] = (0, import_core.useGetState)(); const { onInstanceCreated } = (0, import_usePropsReactive.usePropsReactive)(props, marker, { setterMap: import_config.setterMap, converterMap: import_config.converterMap }); (0, import_useEvents.useEvents)(marker, props, { eventMap: import_constant.MarkerEventMap, eventList: import_constant.MarkerEventList }); (0, import_react.useImperativeHandle)(ref, () => marker, [marker]); const handleClick = (e) => { var _a; (_a = props.onClick) == null ? void 0 : _a.call(props, { type: "click", target: getMarker(), originalEvent: e }); }; const handleDoubleClick = (e) => { e.stopPropagation(); e.preventDefault(); }; (0, import_react.useEffect)(() => { if (map) { createInstance().then((marker2) => { setMarker(marker2); marker2.addTo(map); container.addEventListener("click", handleClick); container.addEventListener("dblclick", handleDoubleClick); onInstanceCreated(); }); } return () => { if (container) { container.removeEventListener("click", handleClick); container.removeEventListener("dblclick", handleClick); } }; }, [map]); const createInstance = () => { const options = getCreateOptions(props); if (options.lngLat) { const marker2 = new import_mapbox_gl.default.Marker(container, options); marker2.setLngLat(options.lngLat); return Promise.resolve(marker2); } else { return Promise.reject(); } }; const getCreateOptions = (props2) => { const options = {}; import_config.allProps.forEach((key) => { if (key in props2) { options[key] = getSetterValue(key, props2); } }); return options; }; const getSetterValue = (key, props2) => { var _a, _b; let value = props2[key]; if (key in import_config.converterMap) { try { value = (_b = (_a = import_config.converterMap)[key]) == null ? void 0 : _b.call(_a, props2[key]); } catch (error) { } } return value; }; return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, marker && /* @__PURE__ */ import_react.default.createElement(Portal, null, props.children)); });