UNPKG

@pansy/react-mapbox-gl

Version:

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

108 lines (106 loc) 4.53 kB
var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; 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 __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/Map/map.tsx var map_exports = {}; __export(map_exports, { Map: () => Map }); module.exports = __toCommonJS(map_exports); var import_mapbox_gl = __toESM(require("mapbox-gl")); var import_react = __toESM(require("react")); var import_useEvents = require("../../hooks/useEvents"); var import_usePropsReactive = require("../../hooks/usePropsReactive"); var import_context = require("./context"); var import_config = require("./config"); var import_constant = require("./constant"); var Map = (0, import_react.forwardRef)((props, ref) => { const { className, loading, containerStyle, children } = props; const containerRef = (0, import_react.useRef)(null); const [mapInstance, setMapInstance] = (0, import_react.useState)(); const style = (0, import_react.useMemo)( () => __spreadValues({ position: "relative", width: "100%", height: "100%" }, containerStyle), [containerStyle] ); const getCreateOptions = (props2) => { const container = containerRef.current; const options = { container }; import_config.allProps.forEach((key) => { if (key in props2 && key !== "container") options[key] = props2[key]; }); return options; }; const createInstance = () => { const options = getCreateOptions(props); return Promise.resolve(new import_mapbox_gl.default.Map(options)); }; const { current: contextValue } = (0, import_react.useRef)({}); const { onInstanceCreated } = (0, import_usePropsReactive.usePropsReactive)(props, mapInstance, { setterMap: import_config.setterMap, converterMap: import_config.converterMap }); (0, import_useEvents.useEvents)(mapInstance, props, { eventMap: import_constant.MapEventMap, eventList: import_constant.MapEventList }); (0, import_react.useImperativeHandle)(ref, () => mapInstance, [mapInstance]); (0, import_react.useEffect)(() => { if (!containerRef.current) return; createInstance().then((map) => { onInstanceCreated(); contextValue.map = map; setMapInstance(map); }); }, [containerRef]); const CHILD_CONTAINER_STYLE = { height: "100%" }; return /* @__PURE__ */ import_react.default.createElement("div", { ref: containerRef, style, className }, !mapInstance && loading, mapInstance && /* @__PURE__ */ import_react.default.createElement(import_context.MapContext.Provider, { value: contextValue }, /* @__PURE__ */ import_react.default.createElement("div", { style: CHILD_CONTAINER_STYLE }, children))); }); Map.displayName = "Map";