diff --git a/.next/cache/webpack/client-development/0.pack.gz b/.next/cache/webpack/client-development/0.pack.gz index a9d8fecd1..d63f7f107 100644 Binary files a/.next/cache/webpack/client-development/0.pack.gz and b/.next/cache/webpack/client-development/0.pack.gz differ diff --git a/.next/cache/webpack/client-development/3.pack.gz b/.next/cache/webpack/client-development/3.pack.gz index bf6cc30c8..a91896564 100644 Binary files a/.next/cache/webpack/client-development/3.pack.gz and b/.next/cache/webpack/client-development/3.pack.gz differ diff --git a/.next/cache/webpack/client-development/index.pack.gz b/.next/cache/webpack/client-development/index.pack.gz index db271759f..4b3c44913 100644 Binary files a/.next/cache/webpack/client-development/index.pack.gz and b/.next/cache/webpack/client-development/index.pack.gz differ diff --git a/.next/cache/webpack/client-development/index.pack.gz.old b/.next/cache/webpack/client-development/index.pack.gz.old index 91d4b4aee..207cdf710 100644 Binary files a/.next/cache/webpack/client-development/index.pack.gz.old and b/.next/cache/webpack/client-development/index.pack.gz.old differ diff --git a/.next/cache/webpack/server-development/0.pack.gz b/.next/cache/webpack/server-development/0.pack.gz index 53c65d266..97bc0c2ef 100644 Binary files a/.next/cache/webpack/server-development/0.pack.gz and b/.next/cache/webpack/server-development/0.pack.gz differ diff --git a/.next/cache/webpack/server-development/1.pack.gz b/.next/cache/webpack/server-development/1.pack.gz index 623bc2097..3de059a2d 100644 Binary files a/.next/cache/webpack/server-development/1.pack.gz and b/.next/cache/webpack/server-development/1.pack.gz differ diff --git a/.next/cache/webpack/server-development/2.pack.gz b/.next/cache/webpack/server-development/2.pack.gz index 43cc999a9..fe002f07b 100644 Binary files a/.next/cache/webpack/server-development/2.pack.gz and b/.next/cache/webpack/server-development/2.pack.gz differ diff --git a/.next/cache/webpack/server-development/3.pack.gz b/.next/cache/webpack/server-development/3.pack.gz index c02bd2ead..d044332f7 100644 Binary files a/.next/cache/webpack/server-development/3.pack.gz and b/.next/cache/webpack/server-development/3.pack.gz differ diff --git a/.next/cache/webpack/server-development/5.pack.gz b/.next/cache/webpack/server-development/5.pack.gz index fbf1924ba..841232be1 100644 Binary files a/.next/cache/webpack/server-development/5.pack.gz and b/.next/cache/webpack/server-development/5.pack.gz differ diff --git a/.next/cache/webpack/server-development/index.pack.gz b/.next/cache/webpack/server-development/index.pack.gz index 5a9e7696c..135e6a2cb 100644 Binary files a/.next/cache/webpack/server-development/index.pack.gz and b/.next/cache/webpack/server-development/index.pack.gz differ diff --git a/.next/cache/webpack/server-development/index.pack.gz.old b/.next/cache/webpack/server-development/index.pack.gz.old index b355d8927..b264aa7ab 100644 Binary files a/.next/cache/webpack/server-development/index.pack.gz.old and b/.next/cache/webpack/server-development/index.pack.gz.old differ diff --git a/.next/server/components_MapComponent_js.js b/.next/server/components_MapComponent_js.js index 7b34b0d6a..c803c6933 100644 --- a/.next/server/components_MapComponent_js.js +++ b/.next/server/components_MapComponent_js.js @@ -17,7 +17,7 @@ exports.modules = { \************************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"react/jsx-dev-runtime\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! leaflet */ \"leaflet\");\n/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(leaflet__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! leaflet/dist/leaflet.css */ \"./node_modules/leaflet/dist/leaflet.css\");\n/* harmony import */ var leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\nconst MapComponent = ()=>{\n const mapRef = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(null);\n const [map, setMap] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n function addMarker(map) {\n const marker = leaflet__WEBPACK_IMPORTED_MODULE_2___default().marker([\n 53.111111,\n 8.4625\n ]).addTo(map);\n marker.bindPopup(\"Hallo Welt!
Ich bin ein Popup.\").openPopup();\n }\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (mapRef.current && !map) {\n const initialMap = leaflet__WEBPACK_IMPORTED_MODULE_2___default().map(mapRef.current, {\n center: [\n 53.111111,\n 8.4625\n ],\n zoom: 10,\n zoomControl: false\n });\n initialMap.on(\"contextmenu\", (event)=>{\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().popup().setLatLng(event.latlng).setContent(`\r\n

\r\n \r\n \r\n \r\n

`).openOn(initialMap);\n });\n window.zoomIn = ()=>{\n initialMap.zoomIn();\n };\n window.zoomOut = ()=>{\n initialMap.zoomOut();\n };\n window.centerHere = (lat, lng)=>{\n initialMap.panTo(new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().LatLng)(lat, lng));\n };\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().tileLayer(\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\", {\n attribution: '© OpenStreetMap contributors'\n }).addTo(initialMap);\n addMarker(initialMap);\n setMap(initialMap);\n }\n }, [\n mapRef,\n map\n ]);\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n id: \"map\",\n ref: mapRef,\n style: {\n height: \"100vh\",\n width: \"100vw\",\n overflow: \"hidden\"\n }\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\components\\\\MapComponent.js\",\n lineNumber: 59,\n columnNumber: 5\n }, undefined);\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (MapComponent);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9jb21wb25lbnRzL01hcENvbXBvbmVudC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQTJEO0FBQ25DO0FBQ1U7QUFFbEMsTUFBTUssZUFBZTtJQUNuQixNQUFNQyxTQUFTSiw2Q0FBTUEsQ0FBQztJQUN0QixNQUFNLENBQUNLLEtBQUtDLE9BQU8sR0FBR0wsK0NBQVFBLENBQUM7SUFFL0IsU0FBU00sVUFBVUYsR0FBRztRQUNwQixNQUFNRyxTQUFTTixxREFBUSxDQUFDO1lBQUM7WUFBVztTQUFPLEVBQUVPLEtBQUssQ0FBQ0o7UUFDbkRHLE9BQU9FLFNBQVMsQ0FBQyw0Q0FBNENDLFNBQVM7SUFDeEU7SUFFQVosZ0RBQVNBLENBQUM7UUFDUixJQUFJSyxPQUFPUSxPQUFPLElBQUksQ0FBQ1AsS0FBSztZQUMxQixNQUFNUSxhQUFhWCxrREFBSyxDQUFDRSxPQUFPUSxPQUFPLEVBQUU7Z0JBQ3ZDRSxRQUFRO29CQUFDO29CQUFXO2lCQUFPO2dCQUMzQkMsTUFBTTtnQkFDTkMsYUFBYTtZQUNmO1lBRUFILFdBQVdJLEVBQUUsQ0FBQyxlQUFlLENBQUNDO2dCQUM1QmhCLG9EQUFPLEdBQ0prQixTQUFTLENBQUNGLE1BQU1HLE1BQU0sRUFDdEJDLFVBQVUsQ0FDVCxDQUFDOzs7OzBDQUk2QixFQUFFSixNQUFNRyxNQUFNLENBQUNFLEdBQUcsQ0FBQyxFQUFFLEVBQUVMLE1BQU1HLE1BQU0sQ0FBQ0csR0FBRyxDQUFDO2dCQUNsRSxDQUFDLEVBRU5DLE1BQU0sQ0FBQ1o7WUFDWjtZQUVBYSxPQUFPQyxNQUFNLEdBQUc7Z0JBQ2RkLFdBQVdjLE1BQU07WUFDbkI7WUFFQUQsT0FBT0UsT0FBTyxHQUFHO2dCQUNmZixXQUFXZSxPQUFPO1lBQ3BCO1lBRUFGLE9BQU9HLFVBQVUsR0FBRyxDQUFDTixLQUFLQztnQkFDeEJYLFdBQVdpQixLQUFLLENBQUMsSUFBSTVCLHVEQUFRLENBQUNxQixLQUFLQztZQUNyQztZQUVBdEIsd0RBQVcsQ0FBQyxzREFBc0Q7Z0JBQ2hFK0IsYUFDRTtZQUNKLEdBQUd4QixLQUFLLENBQUNJO1lBQ1ROLFVBQVVNO1lBRVZQLE9BQU9PO1FBQ1Q7SUFDRixHQUFHO1FBQUNUO1FBQVFDO0tBQUk7SUFFaEIscUJBQ0UsOERBQUM2QjtRQUNDQyxJQUFHO1FBQ0hDLEtBQUtoQztRQUNMaUMsT0FBTztZQUFFQyxRQUFRO1lBQVNDLE9BQU87WUFBU0MsVUFBVTtRQUFTOzs7Ozs7QUFHbkU7QUFFQSxpRUFBZXJDLFlBQVlBLEVBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9jb21wb25lbnRzL01hcENvbXBvbmVudC5qcz9kMDdkIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcclxuaW1wb3J0IEwgZnJvbSBcImxlYWZsZXRcIjtcclxuaW1wb3J0IFwibGVhZmxldC9kaXN0L2xlYWZsZXQuY3NzXCI7XHJcblxyXG5jb25zdCBNYXBDb21wb25lbnQgPSAoKSA9PiB7XHJcbiAgY29uc3QgbWFwUmVmID0gdXNlUmVmKG51bGwpO1xyXG4gIGNvbnN0IFttYXAsIHNldE1hcF0gPSB1c2VTdGF0ZShudWxsKTtcclxuXHJcbiAgZnVuY3Rpb24gYWRkTWFya2VyKG1hcCkge1xyXG4gICAgY29uc3QgbWFya2VyID0gTC5tYXJrZXIoWzUzLjExMTExMSwgOC40NjI1XSkuYWRkVG8obWFwKTtcclxuICAgIG1hcmtlci5iaW5kUG9wdXAoXCI8Yj5IYWxsbyBXZWx0ITwvYj48YnI+SWNoIGJpbiBlaW4gUG9wdXAuXCIpLm9wZW5Qb3B1cCgpO1xyXG4gIH1cclxuXHJcbiAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgIGlmIChtYXBSZWYuY3VycmVudCAmJiAhbWFwKSB7XHJcbiAgICAgIGNvbnN0IGluaXRpYWxNYXAgPSBMLm1hcChtYXBSZWYuY3VycmVudCwge1xyXG4gICAgICAgIGNlbnRlcjogWzUzLjExMTExMSwgOC40NjI1XSxcclxuICAgICAgICB6b29tOiAxMCxcclxuICAgICAgICB6b29tQ29udHJvbDogZmFsc2UsIC8vIERlYWt0aXZpZXJlIGRpZSBTdGFuZGFyZC1ab29tc3RldWVydW5nXHJcbiAgICAgIH0pO1xyXG5cclxuICAgICAgaW5pdGlhbE1hcC5vbihcImNvbnRleHRtZW51XCIsIChldmVudCkgPT4ge1xyXG4gICAgICAgIEwucG9wdXAoKVxyXG4gICAgICAgICAgLnNldExhdExuZyhldmVudC5sYXRsbmcpXHJcbiAgICAgICAgICAuc2V0Q29udGVudChcclxuICAgICAgICAgICAgYFxyXG4gICAgICAgICAgICA8cD5cclxuICAgICAgICAgICAgICA8YnV0dG9uIG9uY2xpY2s9XCJ6b29tSW4oKVwiPlpvb20gaW48L2J1dHRvbj5cclxuICAgICAgICAgICAgICA8YnV0dG9uIG9uY2xpY2s9XCJ6b29tT3V0KClcIj5ab29tIG91dDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgIDxidXR0b24gb25jbGljaz1cImNlbnRlckhlcmUoJHtldmVudC5sYXRsbmcubGF0fSwgJHtldmVudC5sYXRsbmcubG5nfSlcIj5IaWVyIHplbnRyaWVyZW48L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9wPmBcclxuICAgICAgICAgIClcclxuICAgICAgICAgIC5vcGVuT24oaW5pdGlhbE1hcCk7XHJcbiAgICAgIH0pO1xyXG5cclxuICAgICAgd2luZG93Lnpvb21JbiA9ICgpID0+IHtcclxuICAgICAgICBpbml0aWFsTWFwLnpvb21JbigpO1xyXG4gICAgICB9O1xyXG5cclxuICAgICAgd2luZG93Lnpvb21PdXQgPSAoKSA9PiB7XHJcbiAgICAgICAgaW5pdGlhbE1hcC56b29tT3V0KCk7XHJcbiAgICAgIH07XHJcblxyXG4gICAgICB3aW5kb3cuY2VudGVySGVyZSA9IChsYXQsIGxuZykgPT4ge1xyXG4gICAgICAgIGluaXRpYWxNYXAucGFuVG8obmV3IEwuTGF0TG5nKGxhdCwgbG5nKSk7XHJcbiAgICAgIH07XHJcblxyXG4gICAgICBMLnRpbGVMYXllcihcImh0dHBzOi8ve3N9LnRpbGUub3BlbnN0cmVldG1hcC5vcmcve3p9L3t4fS97eX0ucG5nXCIsIHtcclxuICAgICAgICBhdHRyaWJ1dGlvbjpcclxuICAgICAgICAgICcmY29weTsgPGEgaHJlZj1cImh0dHBzOi8vd3d3Lm9wZW5zdHJlZXRtYXAub3JnL2NvcHlyaWdodFwiPk9wZW5TdHJlZXRNYXA8L2E+IGNvbnRyaWJ1dG9ycycsXHJcbiAgICAgIH0pLmFkZFRvKGluaXRpYWxNYXApO1xyXG4gICAgICBhZGRNYXJrZXIoaW5pdGlhbE1hcCk7XHJcblxyXG4gICAgICBzZXRNYXAoaW5pdGlhbE1hcCk7XHJcbiAgICB9XHJcbiAgfSwgW21hcFJlZiwgbWFwXSk7XHJcblxyXG4gIHJldHVybiAoXHJcbiAgICA8ZGl2XHJcbiAgICAgIGlkPVwibWFwXCJcclxuICAgICAgcmVmPXttYXBSZWZ9XHJcbiAgICAgIHN0eWxlPXt7IGhlaWdodDogXCIxMDB2aFwiLCB3aWR0aDogXCIxMDB2d1wiLCBvdmVyZmxvdzogXCJoaWRkZW5cIiB9fVxyXG4gICAgPjwvZGl2PlxyXG4gICk7XHJcbn07XHJcblxyXG5leHBvcnQgZGVmYXVsdCBNYXBDb21wb25lbnQ7XHJcbiJdLCJuYW1lcyI6WyJSZWFjdCIsInVzZUVmZmVjdCIsInVzZVJlZiIsInVzZVN0YXRlIiwiTCIsIk1hcENvbXBvbmVudCIsIm1hcFJlZiIsIm1hcCIsInNldE1hcCIsImFkZE1hcmtlciIsIm1hcmtlciIsImFkZFRvIiwiYmluZFBvcHVwIiwib3BlblBvcHVwIiwiY3VycmVudCIsImluaXRpYWxNYXAiLCJjZW50ZXIiLCJ6b29tIiwiem9vbUNvbnRyb2wiLCJvbiIsImV2ZW50IiwicG9wdXAiLCJzZXRMYXRMbmciLCJsYXRsbmciLCJzZXRDb250ZW50IiwibGF0IiwibG5nIiwib3Blbk9uIiwid2luZG93Iiwiem9vbUluIiwiem9vbU91dCIsImNlbnRlckhlcmUiLCJwYW5UbyIsIkxhdExuZyIsInRpbGVMYXllciIsImF0dHJpYnV0aW9uIiwiZGl2IiwiaWQiLCJyZWYiLCJzdHlsZSIsImhlaWdodCIsIndpZHRoIiwib3ZlcmZsb3ciXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./components/MapComponent.js\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"react/jsx-dev-runtime\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! leaflet */ \"leaflet\");\n/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(leaflet__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! leaflet/dist/leaflet.css */ \"./node_modules/leaflet/dist/leaflet.css\");\n/* harmony import */ var leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(leaflet_dist_leaflet_css__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var leaflet_contextmenu_dist_leaflet_contextmenu_css__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! leaflet-contextmenu/dist/leaflet.contextmenu.css */ \"./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css\");\n/* harmony import */ var leaflet_contextmenu_dist_leaflet_contextmenu_css__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(leaflet_contextmenu_dist_leaflet_contextmenu_css__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var leaflet_contextmenu__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! leaflet-contextmenu */ \"leaflet-contextmenu\");\n/* harmony import */ var leaflet_contextmenu__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(leaflet_contextmenu__WEBPACK_IMPORTED_MODULE_5__);\n\n\n\n\n\n\nconst MapComponent = ()=>{\n const mapRef = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(null);\n const [map, setMap] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n let initialMap = [];\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (mapRef.current && !map) {\n // Initialisiere die Karte ohne die Standard-Zoomsteuerung\n initialMap = leaflet__WEBPACK_IMPORTED_MODULE_2___default().map(mapRef.current, {\n center: [\n 53.111111,\n 8.4625\n ],\n zoom: 10,\n zoomControl: false,\n contextmenu: true,\n contextmenuItems: [\n {\n text: \"Station hinzuf\\xfcgen\",\n callback: showAddStationPopup\n },\n {\n text: \"Station \\xf6ffnen (Tab)\",\n icon: \"img/screen_new.png\",\n callback: newLink\n },\n {\n text: \"Station \\xf6ffnen\",\n icon: \"img/screen_same.png\",\n callback: sameLink\n },\n {\n text: \"Koordinaten\",\n icon: \"img/screen_same.png\",\n callback: lata\n },\n \"-\",\n {\n text: \"Reinzoomen\",\n callback: zoomIn\n },\n {\n text: \"Rauszoomen\",\n callback: zoomOut\n },\n {\n text: \"Hier zentrieren\",\n callback: centerHere\n }\n ]\n });\n initialMap.flyTo([\n 53.34399291274182,\n 7.607860512806846\n ], 12);\n console.log(initialMap);\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().tileLayer(\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\", {\n attribution: '© OpenStreetMap contributors'\n }).addTo(initialMap);\n setMap(initialMap);\n }\n }, [\n mapRef,\n map\n ]);\n console.log(map);\n if (map) {\n map.flyTo([\n 53.34399291274182,\n 7.607860512806846\n ], 18);\n }\n //-----Kontextmenu----------------\n const newLink = (e)=>{\n try {\n if (!e.relatedTarget || !e.relatedTarget.options) {\n throw new Error(\"relatedTarget or options not defined\");\n }\n alert(\"Neues Fenster: \" + e.relatedTarget.options.test);\n window.open(`../devices/${e.relatedTarget.options.test}`, \"_blank\").focus();\n } catch (error) {\n console.error(\"Failed in newLink function:\", error);\n }\n };\n const sameLink = (e)=>{\n alert(e.relatedTarget.options.test);\n window.open(\"../devices/\" + e.relatedTarget.options.test, \"_parent\").focus();\n };\n const lata = (e)=>{\n alert(\"Breitengrad: \" + e.latlng.lat);\n };\n const zoomIn = (e)=>{\n console.log(e);\n console.log(initialMap);\n console.log(\"zoomIn\");\n /* if (!map) {\r\n console.error(\"Karte ist noch nicht initialisiert in zoomIn.\");\r\n return;\r\n } */ initialMap.flyTo({\n lat: 53.34399291274182,\n lng: 7.607860512806846\n }, 12);\n };\n const zoomOut = (e)=>{\n if (!map) {\n console.error(\"Karte ist noch nicht initialisiert in zoomOut.\");\n return;\n }\n // Annahme: Du willst beim Rauszoomen die aktuelle Position halten\n // und nur den Zoom-Level ändern. Hier reduzieren wir den Zoom-Level um 1.\n const currentZoom = map.getZoom();\n map.flyTo(e.latlng, map.getZoom() - 1);\n };\n const showCoordinates = (e)=>{\n alert(\"Breitengrad: \" + e.latlng.lat + \"\\nL\\xe4ngengrad: \" + e.latlng.lng);\n };\n const showData = (e)=>{\n console.log(e);\n };\n const showTalas = (e)=>{\n map.addLayer(TALAS);\n loadData();\n };\n const hideTalas = (e)=>{\n map.removeLayer(TALAS);\n loadData();\n };\n const showGSM = (e)=>{\n map.addLayer(GMA);\n loadData();\n };\n const hideGSM = (e)=>{\n map.removeLayer(GMA);\n loadData();\n };\n //-----Kontextmenu----ende------------\n const showAddStationPopup = (e)=>{\n const popupContent = leaflet__WEBPACK_IMPORTED_MODULE_2___default().DomUtil.create(\"form\");\n popupContent.innerHTML = `\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n `;\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().popup().setLatLng(e.latlng).setContent(popupContent).openOn(e.relatedTarget);\n };\n const centerHere = (e)=>{\n map.panTo(e.latlng);\n };\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n id: \"map\",\n ref: mapRef,\n style: {\n height: \"100vh\",\n width: \"100vw\",\n overflow: \"hidden\"\n }\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\components\\\\MapComponent.js\",\n lineNumber: 164,\n columnNumber: 5\n }, undefined);\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (MapComponent);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./components/MapComponent.js","mappings":"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","sources":["webpack:///./components/MapComponent.js?d07d"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\r\nimport L from \"leaflet\";\r\nimport \"leaflet/dist/leaflet.css\";\r\nimport \"leaflet-contextmenu/dist/leaflet.contextmenu.css\";\r\nimport \"leaflet-contextmenu\";\r\nconst MapComponent = () => {\r\n  const mapRef = useRef(null);\r\n  const [map, setMap] = useState(null);\r\n\r\n  let initialMap = [];\r\n\r\n  useEffect(() => {\r\n    if (mapRef.current && !map) {\r\n      // Initialisiere die Karte ohne die Standard-Zoomsteuerung\r\n      initialMap = L.map(mapRef.current, {\r\n        center: [53.111111, 8.4625],\r\n        zoom: 10,\r\n        zoomControl: false, // Deaktiviere die Standard-Zoomsteuerung\r\n        contextmenu: true,\r\n        contextmenuItems: [\r\n          { text: \"Station hinzufügen\", callback: showAddStationPopup },\r\n          {\r\n            text: \"Station öffnen (Tab)\",\r\n            icon: \"img/screen_new.png\",\r\n            callback: newLink,\r\n          },\r\n          {\r\n            text: \"Station öffnen\",\r\n            icon: \"img/screen_same.png\",\r\n            callback: sameLink,\r\n          },\r\n          {\r\n            text: \"Koordinaten\",\r\n            icon: \"img/screen_same.png\",\r\n            callback: lata,\r\n          },\r\n          \"-\", // Divider\r\n          { text: \"Reinzoomen\", callback: zoomIn },\r\n          { text: \"Rauszoomen\", callback: zoomOut },\r\n          { text: \"Hier zentrieren\", callback: centerHere },\r\n        ],\r\n      });\r\n\r\n      initialMap.flyTo([53.34399291274182, 7.607860512806846], 12);\r\n      console.log(initialMap);\r\n      L.tileLayer(\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\", {\r\n        attribution:\r\n          '&copy; <a href=\"https://www.openstreetmap.org/copyright\">OpenStreetMap</a> contributors',\r\n      }).addTo(initialMap);\r\n\r\n      setMap(initialMap);\r\n    }\r\n  }, [mapRef, map]);\r\n\r\n  console.log(map);\r\n  if (map) {\r\n    map.flyTo([53.34399291274182, 7.607860512806846], 18);\r\n  }\r\n  //-----Kontextmenu----------------\r\n  const newLink = (e) => {\r\n    try {\r\n      if (!e.relatedTarget || !e.relatedTarget.options) {\r\n        throw new Error(\"relatedTarget or options not defined\");\r\n      }\r\n      alert(\"Neues Fenster: \" + e.relatedTarget.options.test);\r\n      window\r\n        .open(`../devices/${e.relatedTarget.options.test}`, \"_blank\")\r\n        .focus();\r\n    } catch (error) {\r\n      console.error(\"Failed in newLink function:\", error);\r\n    }\r\n  };\r\n\r\n  const sameLink = (e) => {\r\n    alert(e.relatedTarget.options.test);\r\n    window\r\n      .open(\"../devices/\" + e.relatedTarget.options.test, \"_parent\")\r\n      .focus();\r\n  };\r\n\r\n  const lata = (e) => {\r\n    alert(\"Breitengrad: \" + e.latlng.lat);\r\n  };\r\n\r\n  const zoomIn = (e) => {\r\n    console.log(e);\r\n    console.log(initialMap);\r\n    console.log(\"zoomIn\");\r\n    /* if (!map) {\r\n      console.error(\"Karte ist noch nicht initialisiert in zoomIn.\");\r\n      return;\r\n    } */\r\n\r\n    initialMap.flyTo(\r\n      {\r\n        lat: 53.34399291274182,\r\n        lng: 7.607860512806846,\r\n      },\r\n      12\r\n    );\r\n  };\r\n\r\n  const zoomOut = (e) => {\r\n    if (!map) {\r\n      console.error(\"Karte ist noch nicht initialisiert in zoomOut.\");\r\n      return;\r\n    }\r\n    // Annahme: Du willst beim Rauszoomen die aktuelle Position halten\r\n    // und nur den Zoom-Level ändern. Hier reduzieren wir den Zoom-Level um 1.\r\n    const currentZoom = map.getZoom();\r\n    map.flyTo(e.latlng, map.getZoom() - 1);\r\n  };\r\n\r\n  const showCoordinates = (e) => {\r\n    alert(\"Breitengrad: \" + e.latlng.lat + \"\\nLängengrad: \" + e.latlng.lng);\r\n  };\r\n  const showData = (e) => {\r\n    console.log(e);\r\n  };\r\n  const showTalas = (e) => {\r\n    map.addLayer(TALAS);\r\n    loadData();\r\n  };\r\n  const hideTalas = (e) => {\r\n    map.removeLayer(TALAS);\r\n    loadData();\r\n  };\r\n  const showGSM = (e) => {\r\n    map.addLayer(GMA);\r\n    loadData();\r\n  };\r\n  const hideGSM = (e) => {\r\n    map.removeLayer(GMA);\r\n    loadData();\r\n  };\r\n  //-----Kontextmenu----ende------------\r\n\r\n  const showAddStationPopup = (e) => {\r\n    const popupContent = L.DomUtil.create(\"form\");\r\n    popupContent.innerHTML = `\r\n      <div style=\"margin: 0; padding: 0; width: 200px;\">\r\n        <label>Name:</label><input type=\"text\" id=\"name\" name=\"name\" placeholder=\"Name der Station\"><br>\r\n        <label>Typ:</label><input type=\"text\" id=\"type\" name=\"type\" placeholder=\"Typ der Station\"><br>\r\n        <label>Breitengrad:</label><input type=\"text\" id=\"lat\" name=\"lat\" value=\"${e.latlng.lat.toFixed(\r\n          5\r\n        )}\" readonly><br>\r\n        <label>Längengrad:</label><input type=\"text\" id=\"lng\" name=\"lng\" value=\"${e.latlng.lng.toFixed(\r\n          5\r\n        )}\" readonly><br>\r\n        <button type=\"submit\">Station hinzufügen</button>\r\n      </div>\r\n    `;\r\n    L.popup()\r\n      .setLatLng(e.latlng)\r\n      .setContent(popupContent)\r\n      .openOn(e.relatedTarget);\r\n  };\r\n\r\n  const centerHere = (e) => {\r\n    map.panTo(e.latlng);\r\n  };\r\n\r\n  return (\r\n    <div\r\n      id=\"map\"\r\n      ref={mapRef}\r\n      style={{ height: \"100vh\", width: \"100vw\", overflow: \"hidden\" }}\r\n    ></div>\r\n  );\r\n};\r\n\r\nexport default MapComponent;\r\n"],"names":["React","useEffect","useRef","useState","L","MapComponent","mapRef","map","setMap","initialMap","current","center","zoom","zoomControl","contextmenu","contextmenuItems","text","callback","showAddStationPopup","icon","newLink","sameLink","lata","zoomIn","zoomOut","centerHere","flyTo","console","log","tileLayer","attribution","addTo","e","relatedTarget","options","Error","alert","test","window","open","focus","error","latlng","lat","lng","currentZoom","getZoom","showCoordinates","showData","showTalas","addLayer","TALAS","loadData","hideTalas","removeLayer","showGSM","GMA","hideGSM","popupContent","DomUtil","create","innerHTML","toFixed","popup","setLatLng","setContent","openOn","panTo","div","id","ref","style","height","width","overflow"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./components/MapComponent.js\n"); /***/ }) diff --git a/.next/server/pages/index.js b/.next/server/pages/index.js index 7a1a3c217..57aeb3513 100644 --- a/.next/server/pages/index.js +++ b/.next/server/pages/index.js @@ -41,7 +41,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Home)\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"react/jsx-dev-runtime\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! next/dynamic */ \"./node_modules/next/dynamic.js\");\n/* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_dynamic__WEBPACK_IMPORTED_MODULE_2__);\n// pages/index.js\n\n\n\nconst MapComponentWithNoSSR = next_dynamic__WEBPACK_IMPORTED_MODULE_2___default()(()=>Promise.all(/*! import() */[__webpack_require__.e(\"vendor-chunks/leaflet\"), __webpack_require__.e(\"components_MapComponent_js\")]).then(__webpack_require__.bind(__webpack_require__, /*! ../components/MapComponent */ \"./components/MapComponent.js\")), {\n loadableGenerated: {\n modules: [\n \"pages\\\\index.js -> \" + \"../components/MapComponent\"\n ]\n },\n ssr: false\n});\nfunction Home() {\n const [mParam, setMParam] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([\n \"\"\n ]);\n const [uParam, setUParam] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([\n \"\"\n ]);\n const [locations, setLocations] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n const [formData, setFormData] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n });\n const loadData = async ()=>{\n const response = await fetch(\"/api/locations\");\n const data = await response.json();\n setLocations(data);\n };\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n // Funktion, um URL-Parameter zu holen\n function getURLParameter(name) {\n // Nutze URLSearchParams, eine Web API für die Arbeit mit Query-Strings\n const params = new URLSearchParams(window.location.search);\n return params.get(name); // Holt den Wert des Parameternamens\n }\n // Hole die Parameter 'm' und 'u'\n setMParam(getURLParameter(\"m\"));\n setUParam(getURLParameter(\"u\"));\n // Logge die Werte in der Konsole\n console.log(`Parameter m: ${mParam}, Parameter u: ${uParam}`);\n loadData();\n }, []);\n const handleAddLocation = async (name, type, lat, lng)=>{\n const response = await fetch(\"/api/addLocation\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n name,\n type,\n latitude: lat,\n longitude: lng\n })\n });\n if (response.ok) {\n console.log(\"Standort erfolgreich hinzugef\\xfcgt\");\n setFormData({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n }); // Formular zurücksetzen\n loadData(); // Daten erneut laden\n } else {\n console.error(\"Fehler beim Hinzuf\\xfcgen des Standorts\");\n }\n };\n const handleSubmit = async (event)=>{\n event.preventDefault();\n const response = await fetch(\"/api/addLocation\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify(formData)\n });\n if (response.ok) {\n console.log(\"Erfolg\");\n setFormData({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n }); // Formular zurücksetzen\n loadData(); // Daten erneut laden\n } else {\n console.error(\"Fehler beim Speichern der Daten\");\n }\n };\n const handleChange = (event)=>{\n const { name, value } = event.target;\n setFormData((prevState)=>({\n ...prevState,\n [name]: value\n }));\n };\n const handleLocationUpdate = (id, newLatitude, newLongitude)=>{\n setLocations((prevLocations)=>{\n return prevLocations.map((location)=>{\n if (location.idPoi === id) {\n return {\n ...location,\n // Hier musst du ggf. die Formatierung anpassen, je nachdem wie du die Koordinaten speicherst\n position: `POINT(${newLongitude} ${newLatitude})`\n };\n }\n return location;\n });\n });\n };\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(MapComponentWithNoSSR, {\n locations: locations,\n onAddLocation: handleAddLocation,\n onLocationUpdate: handleLocationUpdate\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\pages\\\\index.js\",\n lineNumber: 104,\n columnNumber: 7\n }, this)\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\pages\\\\index.js\",\n lineNumber: 102,\n columnNumber: 5\n }, this);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./pages/index.js","mappings":"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","sources":["webpack:///./pages/index.js?bee7"],"sourcesContent":["// pages/index.js\r\nimport { useEffect, useState } from \"react\";\r\nimport dynamic from \"next/dynamic\";\r\n\r\n\r\nconst MapComponentWithNoSSR = dynamic(\r\n  () => import(\"../components/MapComponent\"),\r\n  { ssr: false }\r\n);\r\n\r\nexport default function Home() {\r\n\r\n  const [mParam,setMParam] = useState([\"\"]);\r\n  const [uParam,setUParam] = useState([\"\"]);\r\n\r\n  const [locations, setLocations] = useState([]);\r\n  const [formData, setFormData] = useState({\r\n    name: \"\",\r\n    longitude: \"\",\r\n    latitude: \"\",\r\n    type: \"\",\r\n  });\r\n\r\n  const loadData = async () => {\r\n    const response = await fetch(\"/api/locations\");\r\n    const data = await response.json();\r\n    setLocations(data);\r\n  };\r\n\r\n  useEffect(() => {\r\n       // Funktion, um URL-Parameter zu holen\r\n       function getURLParameter(name) {\r\n        // Nutze URLSearchParams, eine Web API für die Arbeit mit Query-Strings\r\n        const params = new URLSearchParams(window.location.search);\r\n        return params.get(name); // Holt den Wert des Parameternamens\r\n      }\r\n  \r\n      // Hole die Parameter 'm' und 'u'\r\n      setMParam(getURLParameter('m'));\r\n      setUParam(getURLParameter('u'));\r\n  \r\n      // Logge die Werte in der Konsole\r\n      console.log(`Parameter m: ${mParam}, Parameter u: ${uParam}`);\r\n    loadData();\r\n  }, []);\r\n  const handleAddLocation = async (name, type, lat, lng) => {\r\n    const response = await fetch(\"/api/addLocation\", {\r\n      method: \"POST\",\r\n      headers: { \"Content-Type\": \"application/json\" },\r\n      body: JSON.stringify({\r\n        name,\r\n        type,\r\n        latitude: lat,\r\n        longitude: lng,\r\n      }),\r\n    });\r\n\r\n    if (response.ok) {\r\n      console.log(\"Standort erfolgreich hinzugefügt\");\r\n      setFormData({ name: \"\", longitude: \"\", latitude: \"\", type: \"\" }); // Formular zurücksetzen\r\n      loadData(); // Daten erneut laden\r\n    } else {\r\n      console.error(\"Fehler beim Hinzufügen des Standorts\");\r\n    }\r\n  };\r\n  const handleSubmit = async (event) => {\r\n    event.preventDefault();\r\n    const response = await fetch(\"/api/addLocation\", {\r\n      method: \"POST\",\r\n      headers: { \"Content-Type\": \"application/json\" },\r\n      body: JSON.stringify(formData),\r\n    });\r\n\r\n    if (response.ok) {\r\n      console.log(\"Erfolg\");\r\n      setFormData({ name: \"\", longitude: \"\", latitude: \"\", type: \"\" }); // Formular zurücksetzen\r\n      loadData(); // Daten erneut laden\r\n    } else {\r\n      console.error(\"Fehler beim Speichern der Daten\");\r\n    }\r\n  };\r\n\r\n  const handleChange = (event) => {\r\n    const { name, value } = event.target;\r\n    setFormData((prevState) => ({ ...prevState, [name]: value }));\r\n  };\r\n  const handleLocationUpdate = (id, newLatitude, newLongitude) => {\r\n    setLocations((prevLocations) => {\r\n      return prevLocations.map((location) => {\r\n        if (location.idPoi === id) {\r\n          return {\r\n            ...location,\r\n            // Hier musst du ggf. die Formatierung anpassen, je nachdem wie du die Koordinaten speicherst\r\n            position: `POINT(${newLongitude} ${newLatitude})`\r\n          };\r\n        }\r\n        return location;\r\n      });\r\n    });\r\n  };\r\n  return (\r\n    <div>\r\n      {/* Ihr Formular */}\r\n      <MapComponentWithNoSSR\r\n        locations={locations}\r\n        onAddLocation={handleAddLocation}\r\n        onLocationUpdate={handleLocationUpdate}\r\n      />     \r\n    </div>\r\n  );\r\n}"],"names":["useEffect","useState","dynamic","MapComponentWithNoSSR","ssr","Home","mParam","setMParam","uParam","setUParam","locations","setLocations","formData","setFormData","name","longitude","latitude","type","loadData","response","fetch","data","json","getURLParameter","params","URLSearchParams","window","location","search","get","console","log","handleAddLocation","lat","lng","method","headers","body","JSON","stringify","ok","error","handleSubmit","event","preventDefault","handleChange","value","target","prevState","handleLocationUpdate","id","newLatitude","newLongitude","prevLocations","map","idPoi","position","div","onAddLocation","onLocationUpdate"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./pages/index.js\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Home)\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"react/jsx-dev-runtime\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! next/dynamic */ \"./node_modules/next/dynamic.js\");\n/* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_dynamic__WEBPACK_IMPORTED_MODULE_2__);\n// pages/index.js\n\n\n\nconst MapComponentWithNoSSR = next_dynamic__WEBPACK_IMPORTED_MODULE_2___default()(()=>Promise.all(/*! import() */[__webpack_require__.e(\"vendor-chunks/leaflet\"), __webpack_require__.e(\"vendor-chunks/leaflet-contextmenu\"), __webpack_require__.e(\"components_MapComponent_js\")]).then(__webpack_require__.bind(__webpack_require__, /*! ../components/MapComponent */ \"./components/MapComponent.js\")), {\n loadableGenerated: {\n modules: [\n \"pages\\\\index.js -> \" + \"../components/MapComponent\"\n ]\n },\n ssr: false\n});\nfunction Home() {\n const [mParam, setMParam] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([\n \"\"\n ]);\n const [uParam, setUParam] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([\n \"\"\n ]);\n const [locations, setLocations] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n const [formData, setFormData] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n });\n const loadData = async ()=>{\n const response = await fetch(\"/api/locations\");\n const data = await response.json();\n setLocations(data);\n };\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n // Funktion, um URL-Parameter zu holen\n function getURLParameter(name) {\n // Nutze URLSearchParams, eine Web API für die Arbeit mit Query-Strings\n const params = new URLSearchParams(window.location.search);\n return params.get(name); // Holt den Wert des Parameternamens\n }\n // Hole die Parameter 'm' und 'u'\n setMParam(getURLParameter(\"m\"));\n setUParam(getURLParameter(\"u\"));\n // Logge die Werte in der Konsole\n console.log(`Parameter m: ${mParam}, Parameter u: ${uParam}`);\n loadData();\n }, []);\n const handleAddLocation = async (name, type, lat, lng)=>{\n const response = await fetch(\"/api/addLocation\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n name,\n type,\n latitude: lat,\n longitude: lng\n })\n });\n if (response.ok) {\n console.log(\"Standort erfolgreich hinzugef\\xfcgt\");\n setFormData({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n }); // Formular zurücksetzen\n loadData(); // Daten erneut laden\n } else {\n console.error(\"Fehler beim Hinzuf\\xfcgen des Standorts\");\n }\n };\n const handleSubmit = async (event)=>{\n event.preventDefault();\n const response = await fetch(\"/api/addLocation\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify(formData)\n });\n if (response.ok) {\n console.log(\"Erfolg\");\n setFormData({\n name: \"\",\n longitude: \"\",\n latitude: \"\",\n type: \"\"\n }); // Formular zurücksetzen\n loadData(); // Daten erneut laden\n } else {\n console.error(\"Fehler beim Speichern der Daten\");\n }\n };\n const handleChange = (event)=>{\n const { name, value } = event.target;\n setFormData((prevState)=>({\n ...prevState,\n [name]: value\n }));\n };\n const handleLocationUpdate = (id, newLatitude, newLongitude)=>{\n setLocations((prevLocations)=>{\n return prevLocations.map((location)=>{\n if (location.idPoi === id) {\n return {\n ...location,\n // Hier musst du ggf. die Formatierung anpassen, je nachdem wie du die Koordinaten speicherst\n position: `POINT(${newLongitude} ${newLatitude})`\n };\n }\n return location;\n });\n });\n };\n return /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"div\", {\n children: /*#__PURE__*/ (0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(MapComponentWithNoSSR, {\n locations: locations,\n onAddLocation: handleAddLocation,\n onLocationUpdate: handleLocationUpdate\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\pages\\\\index.js\",\n lineNumber: 104,\n columnNumber: 7\n }, this)\n }, void 0, false, {\n fileName: \"C:\\\\Users\\\\isa.LTW\\\\Desktop\\\\15.04.2024\\\\wwwrootTalas5NodeMap\\\\pages\\\\index.js\",\n lineNumber: 102,\n columnNumber: 5\n }, this);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./pages/index.js","mappings":"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","sources":["webpack:///./pages/index.js?bee7"],"sourcesContent":["// pages/index.js\r\nimport { useEffect, useState } from \"react\";\r\nimport dynamic from \"next/dynamic\";\r\n\r\n\r\nconst MapComponentWithNoSSR = dynamic(\r\n  () => import(\"../components/MapComponent\"),\r\n  { ssr: false }\r\n);\r\n\r\nexport default function Home() {\r\n\r\n  const [mParam,setMParam] = useState([\"\"]);\r\n  const [uParam,setUParam] = useState([\"\"]);\r\n\r\n  const [locations, setLocations] = useState([]);\r\n  const [formData, setFormData] = useState({\r\n    name: \"\",\r\n    longitude: \"\",\r\n    latitude: \"\",\r\n    type: \"\",\r\n  });\r\n\r\n  const loadData = async () => {\r\n    const response = await fetch(\"/api/locations\");\r\n    const data = await response.json();\r\n    setLocations(data);\r\n  };\r\n\r\n  useEffect(() => {\r\n       // Funktion, um URL-Parameter zu holen\r\n       function getURLParameter(name) {\r\n        // Nutze URLSearchParams, eine Web API für die Arbeit mit Query-Strings\r\n        const params = new URLSearchParams(window.location.search);\r\n        return params.get(name); // Holt den Wert des Parameternamens\r\n      }\r\n  \r\n      // Hole die Parameter 'm' und 'u'\r\n      setMParam(getURLParameter('m'));\r\n      setUParam(getURLParameter('u'));\r\n  \r\n      // Logge die Werte in der Konsole\r\n      console.log(`Parameter m: ${mParam}, Parameter u: ${uParam}`);\r\n    loadData();\r\n  }, []);\r\n  const handleAddLocation = async (name, type, lat, lng) => {\r\n    const response = await fetch(\"/api/addLocation\", {\r\n      method: \"POST\",\r\n      headers: { \"Content-Type\": \"application/json\" },\r\n      body: JSON.stringify({\r\n        name,\r\n        type,\r\n        latitude: lat,\r\n        longitude: lng,\r\n      }),\r\n    });\r\n\r\n    if (response.ok) {\r\n      console.log(\"Standort erfolgreich hinzugefügt\");\r\n      setFormData({ name: \"\", longitude: \"\", latitude: \"\", type: \"\" }); // Formular zurücksetzen\r\n      loadData(); // Daten erneut laden\r\n    } else {\r\n      console.error(\"Fehler beim Hinzufügen des Standorts\");\r\n    }\r\n  };\r\n  const handleSubmit = async (event) => {\r\n    event.preventDefault();\r\n    const response = await fetch(\"/api/addLocation\", {\r\n      method: \"POST\",\r\n      headers: { \"Content-Type\": \"application/json\" },\r\n      body: JSON.stringify(formData),\r\n    });\r\n\r\n    if (response.ok) {\r\n      console.log(\"Erfolg\");\r\n      setFormData({ name: \"\", longitude: \"\", latitude: \"\", type: \"\" }); // Formular zurücksetzen\r\n      loadData(); // Daten erneut laden\r\n    } else {\r\n      console.error(\"Fehler beim Speichern der Daten\");\r\n    }\r\n  };\r\n\r\n  const handleChange = (event) => {\r\n    const { name, value } = event.target;\r\n    setFormData((prevState) => ({ ...prevState, [name]: value }));\r\n  };\r\n  const handleLocationUpdate = (id, newLatitude, newLongitude) => {\r\n    setLocations((prevLocations) => {\r\n      return prevLocations.map((location) => {\r\n        if (location.idPoi === id) {\r\n          return {\r\n            ...location,\r\n            // Hier musst du ggf. die Formatierung anpassen, je nachdem wie du die Koordinaten speicherst\r\n            position: `POINT(${newLongitude} ${newLatitude})`\r\n          };\r\n        }\r\n        return location;\r\n      });\r\n    });\r\n  };\r\n  return (\r\n    <div>\r\n      {/* Ihr Formular */}\r\n      <MapComponentWithNoSSR\r\n        locations={locations}\r\n        onAddLocation={handleAddLocation}\r\n        onLocationUpdate={handleLocationUpdate}\r\n      />     \r\n    </div>\r\n  );\r\n}"],"names":["useEffect","useState","dynamic","MapComponentWithNoSSR","ssr","Home","mParam","setMParam","uParam","setUParam","locations","setLocations","formData","setFormData","name","longitude","latitude","type","loadData","response","fetch","data","json","getURLParameter","params","URLSearchParams","window","location","search","get","console","log","handleAddLocation","lat","lng","method","headers","body","JSON","stringify","ok","error","handleSubmit","event","preventDefault","handleChange","value","target","prevState","handleLocationUpdate","id","newLatitude","newLongitude","prevLocations","map","idPoi","position","div","onAddLocation","onLocationUpdate"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./pages/index.js\n"); /***/ }), @@ -66,6 +66,17 @@ module.exports = require("leaflet"); /***/ }), +/***/ "leaflet-contextmenu": +/*!**************************************!*\ + !*** external "leaflet-contextmenu" ***! + \**************************************/ +/***/ ((module) => { + +"use strict"; +module.exports = require("leaflet-contextmenu"); + +/***/ }), + /***/ "next/dist/compiled/next-server/pages.runtime.dev.js": /*!**********************************************************************!*\ !*** external "next/dist/compiled/next-server/pages.runtime.dev.js" ***! diff --git a/.next/static/chunks/components_MapComponent_js.js b/.next/static/chunks/components_MapComponent_js.js index 47e199292..cb26a3631 100644 --- a/.next/static/chunks/components_MapComponent_js.js +++ b/.next/static/chunks/components_MapComponent_js.js @@ -8,6 +8,16 @@ */ (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([["components_MapComponent_js"],{ +/***/ "./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.js": +/*!**********************************************************************!*\ + !*** ./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.js ***! + \**********************************************************************/ +/***/ (function(module, exports, __webpack_require__) { + +eval(__webpack_require__.ts("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*\n\tLeaflet.contextmenu, a context menu for Leaflet.\n\t(c) 2015, Adam Ratcliffe, GeoSmart Maps Limited\n\n\t@preserve\n*/\n\n(function(factory) {\n\t// Packaging/modules magic dance\n\tvar L;\n\tif (true) {\n\t\t// AMD\n\t\t!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(/*! leaflet */ \"./node_modules/leaflet/dist/leaflet-src.js\")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n\t} else {}\n})(function(L) {\nL.Map.mergeOptions({\n contextmenuItems: []\n});\n\nL.Map.ContextMenu = L.Handler.extend({\n _touchstart: L.Browser.msPointer ? 'MSPointerDown' : L.Browser.pointer ? 'pointerdown' : 'touchstart',\n \n statics: {\n BASE_CLS: 'leaflet-contextmenu'\n },\n \n initialize: function (map) {\n L.Handler.prototype.initialize.call(this, map);\n \n this._items = [];\n this._visible = false;\n\n var container = this._container = L.DomUtil.create('div', L.Map.ContextMenu.BASE_CLS, map._container);\n container.style.zIndex = 10000;\n container.style.position = 'absolute';\n\n if (map.options.contextmenuWidth) {\n container.style.width = map.options.contextmenuWidth + 'px';\n }\n\n this._createItems();\n\n L.DomEvent\n .on(container, 'click', L.DomEvent.stop)\n .on(container, 'mousedown', L.DomEvent.stop)\n .on(container, 'dblclick', L.DomEvent.stop)\n .on(container, 'contextmenu', L.DomEvent.stop);\n },\n\n addHooks: function () {\n var container = this._map.getContainer();\n\n L.DomEvent\n .on(container, 'mouseleave', this._hide, this)\n .on(document, 'keydown', this._onKeyDown, this);\n\n if (L.Browser.touch) {\n L.DomEvent.on(document, this._touchstart, this._hide, this);\n }\n\n this._map.on({\n contextmenu: this._show,\n mousedown: this._hide,\n movestart: this._hide,\n zoomstart: this._hide\n }, this);\n },\n\n removeHooks: function () {\n var container = this._map.getContainer();\n\n L.DomEvent\n .off(container, 'mouseleave', this._hide, this)\n .off(document, 'keydown', this._onKeyDown, this);\n\n if (L.Browser.touch) {\n L.DomEvent.off(document, this._touchstart, this._hide, this);\n }\n\n this._map.off({\n contextmenu: this._show,\n mousedown: this._hide,\n movestart: this._hide,\n zoomstart: this._hide\n }, this);\n },\n\n showAt: function (point, data) {\n if (point instanceof L.LatLng) {\n point = this._map.latLngToContainerPoint(point);\n }\n this._showAtPoint(point, data);\n },\n\n hide: function () {\n this._hide();\n },\n\n addItem: function (options) {\n return this.insertItem(options);\n },\n\n insertItem: function (options, index) {\n index = index !== undefined ? index: this._items.length;\n\n var item = this._createItem(this._container, options, index);\n\n this._items.push(item);\n\n this._sizeChanged = true;\n\n this._map.fire('contextmenu.additem', {\n contextmenu: this,\n el: item.el,\n index: index\n });\n\n return item.el;\n },\n\n removeItem: function (item) {\n var container = this._container;\n\n if (!isNaN(item)) {\n item = container.children[item];\n }\n\n if (item) {\n this._removeItem(L.Util.stamp(item));\n\n this._sizeChanged = true;\n\n this._map.fire('contextmenu.removeitem', {\n contextmenu: this,\n el: item\n });\n\n return item;\n }\n\n return null;\n },\n\n removeAllItems: function () {\n var items = this._container.children,\n item;\n\n while (items.length) {\n item = items[0];\n this._removeItem(L.Util.stamp(item));\n }\n return items;\n },\n\n hideAllItems: function () {\n var item, i, l;\n\n for (i = 0, l = this._items.length; i < l; i++) {\n item = this._items[i];\n item.el.style.display = 'none';\n }\n },\n\n showAllItems: function () {\n var item, i, l;\n\n for (i = 0, l = this._items.length; i < l; i++) {\n item = this._items[i];\n item.el.style.display = '';\n }\n },\n\n setDisabled: function (item, disabled) {\n var container = this._container,\n itemCls = L.Map.ContextMenu.BASE_CLS + '-item';\n\n if (!isNaN(item)) {\n item = container.children[item];\n }\n\n if (item && L.DomUtil.hasClass(item, itemCls)) {\n if (disabled) {\n L.DomUtil.addClass(item, itemCls + '-disabled');\n this._map.fire('contextmenu.disableitem', {\n contextmenu: this,\n el: item\n });\n } else {\n L.DomUtil.removeClass(item, itemCls + '-disabled');\n this._map.fire('contextmenu.enableitem', {\n contextmenu: this,\n el: item\n });\n }\n }\n },\n\n isVisible: function () {\n return this._visible;\n },\n\n _createItems: function () {\n var itemOptions = this._map.options.contextmenuItems,\n item,\n i, l;\n\n for (i = 0, l = itemOptions.length; i < l; i++) {\n this._items.push(this._createItem(this._container, itemOptions[i]));\n }\n },\n\n _createItem: function (container, options, index) {\n if (options.separator || options === '-') {\n return this._createSeparator(container, index);\n }\n\n var itemCls = L.Map.ContextMenu.BASE_CLS + '-item',\n cls = options.disabled ? (itemCls + ' ' + itemCls + '-disabled') : itemCls,\n el = this._insertElementAt('a', cls, container, index),\n callback = this._createEventHandler(el, options.callback, options.context, options.hideOnSelect),\n icon = this._getIcon(options),\n iconCls = this._getIconCls(options),\n html = '';\n\n if (icon) {\n html = '';\n } else if (iconCls) {\n html = '';\n }\n\n el.innerHTML = html + options.text;\n el.href = '#';\n\n L.DomEvent\n .on(el, 'mouseover', this._onItemMouseOver, this)\n .on(el, 'mouseout', this._onItemMouseOut, this)\n .on(el, 'mousedown', L.DomEvent.stopPropagation)\n .on(el, 'click', callback);\n\n if (L.Browser.touch) {\n L.DomEvent.on(el, this._touchstart, L.DomEvent.stopPropagation);\n }\n\n // Devices without a mouse fire \"mouseover\" on tap, but never “mouseout\"\n if (!L.Browser.pointer) {\n L.DomEvent.on(el, 'click', this._onItemMouseOut, this);\n }\n\n return {\n id: L.Util.stamp(el),\n el: el,\n callback: callback\n };\n },\n\n _removeItem: function (id) {\n var item,\n el,\n i, l, callback;\n\n for (i = 0, l = this._items.length; i < l; i++) {\n item = this._items[i];\n\n if (item.id === id) {\n el = item.el;\n callback = item.callback;\n\n if (callback) {\n L.DomEvent\n .off(el, 'mouseover', this._onItemMouseOver, this)\n .off(el, 'mouseover', this._onItemMouseOut, this)\n .off(el, 'mousedown', L.DomEvent.stopPropagation)\n .off(el, 'click', callback);\n\n if (L.Browser.touch) {\n L.DomEvent.off(el, this._touchstart, L.DomEvent.stopPropagation);\n }\n\n if (!L.Browser.pointer) {\n L.DomEvent.on(el, 'click', this._onItemMouseOut, this);\n }\n }\n\n this._container.removeChild(el);\n this._items.splice(i, 1);\n\n return item;\n }\n }\n return null;\n },\n\n _createSeparator: function (container, index) {\n var el = this._insertElementAt('div', L.Map.ContextMenu.BASE_CLS + '-separator', container, index);\n\n return {\n id: L.Util.stamp(el),\n el: el\n };\n },\n\n _createEventHandler: function (el, func, context, hideOnSelect) {\n var me = this,\n map = this._map,\n disabledCls = L.Map.ContextMenu.BASE_CLS + '-item-disabled',\n hideOnSelect = (hideOnSelect !== undefined) ? hideOnSelect : true;\n\n return function (e) {\n if (L.DomUtil.hasClass(el, disabledCls)) {\n return;\n }\n\n if (hideOnSelect) {\n me._hide();\n }\n\n if (func) {\n func.call(context || map, me._showLocation);\n }\n\n me._map.fire('contextmenu.select', {\n contextmenu: me,\n el: el\n });\n };\n },\n\n _insertElementAt: function (tagName, className, container, index) {\n var refEl,\n el = document.createElement(tagName);\n\n el.className = className;\n\n if (index !== undefined) {\n refEl = container.children[index];\n }\n\n if (refEl) {\n container.insertBefore(el, refEl);\n } else {\n container.appendChild(el);\n }\n\n return el;\n },\n\n _show: function (e) {\n this._showAtPoint(e.containerPoint, e);\n },\n\n _showAtPoint: function (pt, data) {\n if (this._items.length) {\n var map = this._map,\n layerPoint = map.containerPointToLayerPoint(pt),\n latlng = map.layerPointToLatLng(layerPoint),\n event = L.extend(data || {}, {contextmenu: this});\n\n this._showLocation = {\n latlng: latlng,\n layerPoint: layerPoint,\n containerPoint: pt\n };\n\n if (data && data.relatedTarget){\n this._showLocation.relatedTarget = data.relatedTarget;\n }\n\n this._setPosition(pt);\n\n if (!this._visible) {\n this._container.style.display = 'block';\n this._visible = true;\n }\n\n this._map.fire('contextmenu.show', event);\n }\n },\n\n _hide: function () {\n if (this._visible) {\n this._visible = false;\n this._container.style.display = 'none';\n this._map.fire('contextmenu.hide', {contextmenu: this});\n }\n },\n\n _getIcon: function (options) {\n return L.Browser.retina && options.retinaIcon || options.icon;\n },\n\n _getIconCls: function (options) {\n return L.Browser.retina && options.retinaIconCls || options.iconCls;\n },\n\n _setPosition: function (pt) {\n var mapSize = this._map.getSize(),\n container = this._container,\n containerSize = this._getElementSize(container),\n anchor;\n\n if (this._map.options.contextmenuAnchor) {\n anchor = L.point(this._map.options.contextmenuAnchor);\n pt = pt.add(anchor);\n }\n\n container._leaflet_pos = pt;\n\n if (pt.x + containerSize.x > mapSize.x) {\n container.style.left = 'auto';\n container.style.right = Math.min(Math.max(mapSize.x - pt.x, 0), mapSize.x - containerSize.x - 1) + 'px';\n } else {\n container.style.left = Math.max(pt.x, 0) + 'px';\n container.style.right = 'auto';\n }\n\n if (pt.y + containerSize.y > mapSize.y) {\n container.style.top = 'auto';\n container.style.bottom = Math.min(Math.max(mapSize.y - pt.y, 0), mapSize.y - containerSize.y - 1) + 'px';\n } else {\n container.style.top = Math.max(pt.y, 0) + 'px';\n container.style.bottom = 'auto';\n }\n },\n\n _getElementSize: function (el) {\n var size = this._size,\n initialDisplay = el.style.display;\n\n if (!size || this._sizeChanged) {\n size = {};\n\n el.style.left = '-999999px';\n el.style.right = 'auto';\n el.style.display = 'block';\n\n size.x = el.offsetWidth;\n size.y = el.offsetHeight;\n\n el.style.left = 'auto';\n el.style.display = initialDisplay;\n\n this._sizeChanged = false;\n }\n\n return size;\n },\n\n _onKeyDown: function (e) {\n var key = e.keyCode;\n\n // If ESC pressed and context menu is visible hide it\n if (key === 27) {\n this._hide();\n }\n },\n\n _onItemMouseOver: function (e) {\n L.DomUtil.addClass(e.target || e.srcElement, 'over');\n },\n\n _onItemMouseOut: function (e) {\n L.DomUtil.removeClass(e.target || e.srcElement, 'over');\n }\n});\n\nL.Map.addInitHook('addHandler', 'contextmenu', L.Map.ContextMenu);\nL.Mixin.ContextMenu = {\n bindContextMenu: function (options) {\n L.setOptions(this, options);\n this._initContextMenu();\n\n return this;\n },\n\n unbindContextMenu: function (){\n this.off('contextmenu', this._showContextMenu, this);\n\n return this;\n },\n\n addContextMenuItem: function (item) {\n this.options.contextmenuItems.push(item);\n },\n\n removeContextMenuItemWithIndex: function (index) {\n var items = [];\n for (var i = 0; i < this.options.contextmenuItems.length; i++) {\n if (this.options.contextmenuItems[i].index == index){\n items.push(i);\n }\n }\n var elem = items.pop();\n while (elem !== undefined) {\n this.options.contextmenuItems.splice(elem,1);\n elem = items.pop();\n }\n },\n\n replaceContextMenuItem: function (item) {\n this.removeContextMenuItemWithIndex(item.index);\n this.addContextMenuItem(item);\n },\n\n _initContextMenu: function () {\n this._items = [];\n\n this.on('contextmenu', this._showContextMenu, this);\n },\n\n _showContextMenu: function (e) {\n var itemOptions,\n data, pt, i, l;\n\n if (this._map.contextmenu) {\n data = L.extend({relatedTarget: this}, e);\n\n pt = this._map.mouseEventToContainerPoint(e.originalEvent);\n\n if (!this.options.contextmenuInheritItems) {\n this._map.contextmenu.hideAllItems();\n }\n\n for (i = 0, l = this.options.contextmenuItems.length; i < l; i++) {\n itemOptions = this.options.contextmenuItems[i];\n this._items.push(this._map.contextmenu.insertItem(itemOptions, itemOptions.index));\n }\n\n this._map.once('contextmenu.hide', this._hideContextMenu, this);\n\n this._map.contextmenu.showAt(pt, data);\n }\n },\n\n _hideContextMenu: function () {\n var i, l;\n\n for (i = 0, l = this._items.length; i < l; i++) {\n this._map.contextmenu.removeItem(this._items[i]);\n }\n this._items.length = 0;\n\n if (!this.options.contextmenuInheritItems) {\n this._map.contextmenu.showAllItems();\n }\n }\n};\n\nvar classes = [L.Marker, L.Path],\n defaultOptions = {\n contextmenu: false,\n contextmenuItems: [],\n contextmenuInheritItems: true\n },\n cls, i, l;\n\nfor (i = 0, l = classes.length; i < l; i++) {\n cls = classes[i];\n\n // L.Class should probably provide an empty options hash, as it does not test\n // for it here and add if needed\n if (!cls.prototype.options) {\n cls.prototype.options = defaultOptions;\n } else {\n cls.mergeOptions(defaultOptions);\n }\n\n cls.addInitHook(function () {\n if (this.options.contextmenu) {\n this._initContextMenu();\n }\n });\n\n cls.include(L.Mixin.ContextMenu);\n}\nreturn L.Map.ContextMenu;\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.js","mappings":"AAAA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK,IAA0C;AAC/C;AACA,EAAE,iCAAO,CAAC,gFAAS,CAAC,oCAAE,OAAO;AAAA;AAAA;AAAA,kGAAC;AAC9B,GAAG,KAAK,EAUN;AACF,CAAC;AACD;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,aAAa;;AAEb;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA,4CAA4C,OAAO;AACnD;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA,4CAA4C,OAAO;AACnD;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,cAAc;AACd;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA,4CAA4C,OAAO;AACnD;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA,4CAA4C,OAAO;AACnD;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,uCAAuC,GAAG,kBAAkB;;AAE5D;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA,gDAAgD,kBAAkB;AAClE;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA,wBAAwB,0CAA0C;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA,6BAA6B,oBAAoB;;AAEjD;;AAEA;AACA;AACA;;AAEA,kEAAkE,OAAO;AACzE;AACA;AACA;;AAEA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA,4CAA4C,OAAO;AACnD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,gCAAgC,OAAO;AACvC;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,CAAC","sources":["webpack://_N_E/./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.js?5d0e"],"sourcesContent":["/*\n\tLeaflet.contextmenu, a context menu for Leaflet.\n\t(c) 2015, Adam Ratcliffe, GeoSmart Maps Limited\n\n\t@preserve\n*/\n\n(function(factory) {\n\t// Packaging/modules magic dance\n\tvar L;\n\tif (typeof define === 'function' && define.amd) {\n\t\t// AMD\n\t\tdefine(['leaflet'], factory);\n\t} else if (typeof module === 'object' && typeof module.exports === 'object') {\n\t\t// Node/CommonJS\n\t\tL = require('leaflet');\n\t\tmodule.exports = factory(L);\n\t} else {\n\t\t// Browser globals\n\t\tif (typeof window.L === 'undefined') {\n\t\t\tthrow new Error('Leaflet must be loaded first');\n\t\t}\n\t\tfactory(window.L);\n\t}\n})(function(L) {\nL.Map.mergeOptions({\n    contextmenuItems: []\n});\n\nL.Map.ContextMenu = L.Handler.extend({\n    _touchstart: L.Browser.msPointer ? 'MSPointerDown' : L.Browser.pointer ? 'pointerdown' : 'touchstart',\n    \n    statics: {\n        BASE_CLS: 'leaflet-contextmenu'\n    },\n    \n    initialize: function (map) {\n        L.Handler.prototype.initialize.call(this, map);\n        \n        this._items = [];\n        this._visible = false;\n\n        var container = this._container = L.DomUtil.create('div', L.Map.ContextMenu.BASE_CLS, map._container);\n        container.style.zIndex = 10000;\n        container.style.position = 'absolute';\n\n        if (map.options.contextmenuWidth) {\n            container.style.width = map.options.contextmenuWidth + 'px';\n        }\n\n        this._createItems();\n\n        L.DomEvent\n            .on(container, 'click', L.DomEvent.stop)\n            .on(container, 'mousedown', L.DomEvent.stop)\n            .on(container, 'dblclick', L.DomEvent.stop)\n            .on(container, 'contextmenu', L.DomEvent.stop);\n    },\n\n    addHooks: function () {\n        var container = this._map.getContainer();\n\n        L.DomEvent\n            .on(container, 'mouseleave', this._hide, this)\n            .on(document, 'keydown', this._onKeyDown, this);\n\n        if (L.Browser.touch) {\n            L.DomEvent.on(document, this._touchstart, this._hide, this);\n        }\n\n        this._map.on({\n            contextmenu: this._show,\n            mousedown: this._hide,\n            movestart: this._hide,\n            zoomstart: this._hide\n        }, this);\n    },\n\n    removeHooks: function () {\n        var container = this._map.getContainer();\n\n        L.DomEvent\n            .off(container, 'mouseleave', this._hide, this)\n            .off(document, 'keydown', this._onKeyDown, this);\n\n        if (L.Browser.touch) {\n            L.DomEvent.off(document, this._touchstart, this._hide, this);\n        }\n\n        this._map.off({\n            contextmenu: this._show,\n            mousedown: this._hide,\n            movestart: this._hide,\n            zoomstart: this._hide\n        }, this);\n    },\n\n    showAt: function (point, data) {\n        if (point instanceof L.LatLng) {\n            point = this._map.latLngToContainerPoint(point);\n        }\n        this._showAtPoint(point, data);\n    },\n\n    hide: function () {\n        this._hide();\n    },\n\n    addItem: function (options) {\n        return this.insertItem(options);\n    },\n\n    insertItem: function (options, index) {\n        index = index !== undefined ? index: this._items.length;\n\n        var item = this._createItem(this._container, options, index);\n\n        this._items.push(item);\n\n        this._sizeChanged = true;\n\n        this._map.fire('contextmenu.additem', {\n            contextmenu: this,\n            el: item.el,\n            index: index\n        });\n\n        return item.el;\n    },\n\n    removeItem: function (item) {\n        var container = this._container;\n\n        if (!isNaN(item)) {\n            item = container.children[item];\n        }\n\n        if (item) {\n            this._removeItem(L.Util.stamp(item));\n\n            this._sizeChanged = true;\n\n            this._map.fire('contextmenu.removeitem', {\n                contextmenu: this,\n                el: item\n            });\n\n            return item;\n        }\n\n        return null;\n    },\n\n    removeAllItems: function () {\n        var items = this._container.children,\n            item;\n\n        while (items.length) {\n            item = items[0];\n            this._removeItem(L.Util.stamp(item));\n        }\n        return items;\n    },\n\n    hideAllItems: function () {\n        var item, i, l;\n\n        for (i = 0, l = this._items.length; i < l; i++) {\n            item = this._items[i];\n            item.el.style.display = 'none';\n        }\n    },\n\n    showAllItems: function () {\n        var item, i, l;\n\n        for (i = 0, l = this._items.length; i < l; i++) {\n            item = this._items[i];\n            item.el.style.display = '';\n        }\n    },\n\n    setDisabled: function (item, disabled) {\n        var container = this._container,\n        itemCls = L.Map.ContextMenu.BASE_CLS + '-item';\n\n        if (!isNaN(item)) {\n            item = container.children[item];\n        }\n\n        if (item && L.DomUtil.hasClass(item, itemCls)) {\n            if (disabled) {\n                L.DomUtil.addClass(item, itemCls + '-disabled');\n                this._map.fire('contextmenu.disableitem', {\n                    contextmenu: this,\n                    el: item\n                });\n            } else {\n                L.DomUtil.removeClass(item, itemCls + '-disabled');\n                this._map.fire('contextmenu.enableitem', {\n                    contextmenu: this,\n                    el: item\n                });\n            }\n        }\n    },\n\n    isVisible: function () {\n        return this._visible;\n    },\n\n    _createItems: function () {\n        var itemOptions = this._map.options.contextmenuItems,\n            item,\n            i, l;\n\n        for (i = 0, l = itemOptions.length; i < l; i++) {\n            this._items.push(this._createItem(this._container, itemOptions[i]));\n        }\n    },\n\n    _createItem: function (container, options, index) {\n        if (options.separator || options === '-') {\n            return this._createSeparator(container, index);\n        }\n\n        var itemCls = L.Map.ContextMenu.BASE_CLS + '-item',\n            cls = options.disabled ? (itemCls + ' ' + itemCls + '-disabled') : itemCls,\n            el = this._insertElementAt('a', cls, container, index),\n            callback = this._createEventHandler(el, options.callback, options.context, options.hideOnSelect),\n            icon = this._getIcon(options),\n            iconCls = this._getIconCls(options),\n            html = '';\n\n        if (icon) {\n            html = '<img class=\"' + L.Map.ContextMenu.BASE_CLS + '-icon\" src=\"' + icon + '\"/>';\n        } else if (iconCls) {\n            html = '<span class=\"' + L.Map.ContextMenu.BASE_CLS + '-icon ' + iconCls + '\"></span>';\n        }\n\n        el.innerHTML = html + options.text;\n        el.href = '#';\n\n        L.DomEvent\n            .on(el, 'mouseover', this._onItemMouseOver, this)\n            .on(el, 'mouseout', this._onItemMouseOut, this)\n            .on(el, 'mousedown', L.DomEvent.stopPropagation)\n            .on(el, 'click', callback);\n\n        if (L.Browser.touch) {\n            L.DomEvent.on(el, this._touchstart, L.DomEvent.stopPropagation);\n        }\n\n        // Devices without a mouse fire \"mouseover\" on tap, but never “mouseout\"\n        if (!L.Browser.pointer) {\n            L.DomEvent.on(el, 'click', this._onItemMouseOut, this);\n        }\n\n        return {\n            id: L.Util.stamp(el),\n            el: el,\n            callback: callback\n        };\n    },\n\n    _removeItem: function (id) {\n        var item,\n            el,\n            i, l, callback;\n\n        for (i = 0, l = this._items.length; i < l; i++) {\n            item = this._items[i];\n\n            if (item.id === id) {\n                el = item.el;\n                callback = item.callback;\n\n                if (callback) {\n                    L.DomEvent\n                        .off(el, 'mouseover', this._onItemMouseOver, this)\n                        .off(el, 'mouseover', this._onItemMouseOut, this)\n                        .off(el, 'mousedown', L.DomEvent.stopPropagation)\n                        .off(el, 'click', callback);\n\n                    if (L.Browser.touch) {\n                        L.DomEvent.off(el, this._touchstart, L.DomEvent.stopPropagation);\n                    }\n\n                    if (!L.Browser.pointer) {\n                        L.DomEvent.on(el, 'click', this._onItemMouseOut, this);\n                    }\n                }\n\n                this._container.removeChild(el);\n                this._items.splice(i, 1);\n\n                return item;\n            }\n        }\n        return null;\n    },\n\n    _createSeparator: function (container, index) {\n        var el = this._insertElementAt('div', L.Map.ContextMenu.BASE_CLS + '-separator', container, index);\n\n        return {\n            id: L.Util.stamp(el),\n            el: el\n        };\n    },\n\n    _createEventHandler: function (el, func, context, hideOnSelect) {\n        var me = this,\n            map = this._map,\n            disabledCls = L.Map.ContextMenu.BASE_CLS + '-item-disabled',\n            hideOnSelect = (hideOnSelect !== undefined) ? hideOnSelect : true;\n\n        return function (e) {\n            if (L.DomUtil.hasClass(el, disabledCls)) {\n                return;\n            }\n\n            if (hideOnSelect) {\n                me._hide();\n            }\n\n            if (func) {\n                func.call(context || map, me._showLocation);\n            }\n\n            me._map.fire('contextmenu.select', {\n                contextmenu: me,\n                el: el\n            });\n        };\n    },\n\n    _insertElementAt: function (tagName, className, container, index) {\n        var refEl,\n            el = document.createElement(tagName);\n\n        el.className = className;\n\n        if (index !== undefined) {\n            refEl = container.children[index];\n        }\n\n        if (refEl) {\n            container.insertBefore(el, refEl);\n        } else {\n            container.appendChild(el);\n        }\n\n        return el;\n    },\n\n    _show: function (e) {\n        this._showAtPoint(e.containerPoint, e);\n    },\n\n    _showAtPoint: function (pt, data) {\n        if (this._items.length) {\n            var map = this._map,\n            layerPoint = map.containerPointToLayerPoint(pt),\n            latlng = map.layerPointToLatLng(layerPoint),\n            event = L.extend(data || {}, {contextmenu: this});\n\n            this._showLocation = {\n                latlng: latlng,\n                layerPoint: layerPoint,\n                containerPoint: pt\n            };\n\n            if (data && data.relatedTarget){\n                this._showLocation.relatedTarget = data.relatedTarget;\n            }\n\n            this._setPosition(pt);\n\n            if (!this._visible) {\n                this._container.style.display = 'block';\n                this._visible = true;\n            }\n\n            this._map.fire('contextmenu.show', event);\n        }\n    },\n\n    _hide: function () {\n        if (this._visible) {\n            this._visible = false;\n            this._container.style.display = 'none';\n            this._map.fire('contextmenu.hide', {contextmenu: this});\n        }\n    },\n\n    _getIcon: function (options) {\n        return L.Browser.retina && options.retinaIcon || options.icon;\n    },\n\n    _getIconCls: function (options) {\n        return L.Browser.retina && options.retinaIconCls || options.iconCls;\n    },\n\n    _setPosition: function (pt) {\n        var mapSize = this._map.getSize(),\n            container = this._container,\n            containerSize = this._getElementSize(container),\n            anchor;\n\n        if (this._map.options.contextmenuAnchor) {\n            anchor = L.point(this._map.options.contextmenuAnchor);\n            pt = pt.add(anchor);\n        }\n\n        container._leaflet_pos = pt;\n\n        if (pt.x + containerSize.x > mapSize.x) {\n            container.style.left = 'auto';\n            container.style.right = Math.min(Math.max(mapSize.x - pt.x, 0), mapSize.x - containerSize.x - 1) + 'px';\n        } else {\n            container.style.left = Math.max(pt.x, 0) + 'px';\n            container.style.right = 'auto';\n        }\n\n        if (pt.y + containerSize.y > mapSize.y) {\n            container.style.top = 'auto';\n            container.style.bottom = Math.min(Math.max(mapSize.y - pt.y, 0), mapSize.y - containerSize.y - 1) + 'px';\n        } else {\n            container.style.top = Math.max(pt.y, 0) + 'px';\n            container.style.bottom = 'auto';\n        }\n    },\n\n    _getElementSize: function (el) {\n        var size = this._size,\n            initialDisplay = el.style.display;\n\n        if (!size || this._sizeChanged) {\n            size = {};\n\n            el.style.left = '-999999px';\n            el.style.right = 'auto';\n            el.style.display = 'block';\n\n            size.x = el.offsetWidth;\n            size.y = el.offsetHeight;\n\n            el.style.left = 'auto';\n            el.style.display = initialDisplay;\n\n            this._sizeChanged = false;\n        }\n\n        return size;\n    },\n\n    _onKeyDown: function (e) {\n        var key = e.keyCode;\n\n        // If ESC pressed and context menu is visible hide it\n        if (key === 27) {\n            this._hide();\n        }\n    },\n\n    _onItemMouseOver: function (e) {\n        L.DomUtil.addClass(e.target || e.srcElement, 'over');\n    },\n\n    _onItemMouseOut: function (e) {\n        L.DomUtil.removeClass(e.target || e.srcElement, 'over');\n    }\n});\n\nL.Map.addInitHook('addHandler', 'contextmenu', L.Map.ContextMenu);\nL.Mixin.ContextMenu = {\n    bindContextMenu: function (options) {\n        L.setOptions(this, options);\n        this._initContextMenu();\n\n        return this;\n    },\n\n    unbindContextMenu: function (){\n        this.off('contextmenu', this._showContextMenu, this);\n\n        return this;\n    },\n\n    addContextMenuItem: function (item) {\n            this.options.contextmenuItems.push(item);\n    },\n\n    removeContextMenuItemWithIndex: function (index) {\n        var items = [];\n        for (var i = 0; i < this.options.contextmenuItems.length; i++) {\n            if (this.options.contextmenuItems[i].index == index){\n                items.push(i);\n            }\n        }\n        var elem = items.pop();\n        while (elem !== undefined) {\n            this.options.contextmenuItems.splice(elem,1);\n            elem = items.pop();\n        }\n    },\n\n    replaceContextMenuItem: function (item) {\n        this.removeContextMenuItemWithIndex(item.index);\n        this.addContextMenuItem(item);\n    },\n\n    _initContextMenu: function () {\n        this._items = [];\n\n        this.on('contextmenu', this._showContextMenu, this);\n    },\n\n    _showContextMenu: function (e) {\n        var itemOptions,\n            data, pt, i, l;\n\n        if (this._map.contextmenu) {\n            data = L.extend({relatedTarget: this}, e);\n\n            pt = this._map.mouseEventToContainerPoint(e.originalEvent);\n\n            if (!this.options.contextmenuInheritItems) {\n                this._map.contextmenu.hideAllItems();\n            }\n\n            for (i = 0, l = this.options.contextmenuItems.length; i < l; i++) {\n                itemOptions = this.options.contextmenuItems[i];\n                this._items.push(this._map.contextmenu.insertItem(itemOptions, itemOptions.index));\n            }\n\n            this._map.once('contextmenu.hide', this._hideContextMenu, this);\n\n            this._map.contextmenu.showAt(pt, data);\n        }\n    },\n\n    _hideContextMenu: function () {\n        var i, l;\n\n        for (i = 0, l = this._items.length; i < l; i++) {\n            this._map.contextmenu.removeItem(this._items[i]);\n        }\n        this._items.length = 0;\n\n        if (!this.options.contextmenuInheritItems) {\n            this._map.contextmenu.showAllItems();\n        }\n    }\n};\n\nvar classes = [L.Marker, L.Path],\n    defaultOptions = {\n        contextmenu: false,\n        contextmenuItems: [],\n        contextmenuInheritItems: true\n    },\n    cls, i, l;\n\nfor (i = 0, l = classes.length; i < l; i++) {\n    cls = classes[i];\n\n    // L.Class should probably provide an empty options hash, as it does not test\n    // for it here and add if needed\n    if (!cls.prototype.options) {\n        cls.prototype.options = defaultOptions;\n    } else {\n        cls.mergeOptions(defaultOptions);\n    }\n\n    cls.addInitHook(function () {\n        if (this.options.contextmenu) {\n            this._initContextMenu();\n        }\n    });\n\n    cls.include(L.Mixin.ContextMenu);\n}\nreturn L.Map.ContextMenu;\n});\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.js\n")); + +/***/ }), + /***/ "./node_modules/leaflet/dist/leaflet-src.js": /*!**************************************************!*\ !*** ./node_modules/leaflet/dist/leaflet-src.js ***! @@ -18,6 +28,17 @@ eval(__webpack_require__.ts("/* @preserve\n * Leaflet 1.9.4, a JS library for in /***/ }), +/***/ "./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css": +/*!*****************************************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css ***! + \*****************************************************************************************************************************************************************************************************************************************************************************************************/ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _next_dist_build_webpack_loaders_css_loader_src_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../next/dist/build/webpack/loaders/css-loader/src/runtime/api.js */ \"./node_modules/next/dist/build/webpack/loaders/css-loader/src/runtime/api.js\");\n/* harmony import */ var _next_dist_build_webpack_loaders_css_loader_src_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_next_dist_build_webpack_loaders_css_loader_src_runtime_api_js__WEBPACK_IMPORTED_MODULE_0__);\n// Imports\n\nvar ___CSS_LOADER_EXPORT___ = _next_dist_build_webpack_loaders_css_loader_src_runtime_api_js__WEBPACK_IMPORTED_MODULE_0___default()(true);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \".leaflet-contextmenu {\\n display: none;\\n box-shadow: 0 1px 7px rgba(0,0,0,0.4);\\n border-radius: 4px;\\n padding: 4px 0;\\n background-color: #fff;\\n cursor: default;\\n -webkit-user-select: none;\\n -moz-user-select: none;\\n user-select: none;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item {\\n display: block;\\n color: #222;\\n font-size: 12px;\\n line-height: 20px;\\n text-decoration: none;\\n padding: 0 12px;\\n border-top: 1px solid transparent;\\n border-bottom: 1px solid transparent;\\n cursor: default;\\n outline: none;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item-disabled {\\n opacity: 0.5;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item.over {\\n background-color: #f4f4f4;\\n border-top: 1px solid #f0f0f0;\\n border-bottom: 1px solid #f0f0f0;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item-disabled.over {\\n background-color: inherit;\\n border-top: 1px solid transparent;\\n border-bottom: 1px solid transparent;\\n}\\n\\n.leaflet-contextmenu-icon {\\n margin: 2px 8px 0 0;\\n width: 16px;\\n height: 16px;\\n float: left;\\n border: 0;\\n}\\n\\n.leaflet-contextmenu-separator {\\n border-bottom: 1px solid #ccc;\\n margin: 5px 0;\\n}\\n\", \"\",{\"version\":3,\"sources\":[\"webpack://node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,aAAa;IACb,qCAAqC;IAErC,kBAAkB;IAClB,cAAc;IACd,sBAAsB;IACtB,eAAe;IACf,yBAAyB;IACzB,sBAAsB;IACtB,iBAAiB;AACrB;;AAEA;IACI,cAAc;IACd,WAAW;IACX,eAAe;IACf,iBAAiB;IACjB,qBAAqB;IACrB,eAAe;IACf,iCAAiC;IACjC,oCAAoC;IACpC,eAAe;IACf,aAAa;AACjB;;AAEA;IACI,YAAY;AAChB;;AAEA;IACI,yBAAyB;IACzB,6BAA6B;IAC7B,gCAAgC;AACpC;;AAEA;IACI,yBAAyB;IACzB,iCAAiC;IACjC,oCAAoC;AACxC;;AAEA;IACI,mBAAmB;IACnB,WAAW;IACX,YAAY;IACZ,WAAW;IACX,SAAS;AACb;;AAEA;IACI,6BAA6B;IAC7B,aAAa;AACjB\",\"sourcesContent\":[\".leaflet-contextmenu {\\n display: none;\\n box-shadow: 0 1px 7px rgba(0,0,0,0.4);\\n -webkit-border-radius: 4px;\\n border-radius: 4px;\\n padding: 4px 0;\\n background-color: #fff;\\n cursor: default;\\n -webkit-user-select: none;\\n -moz-user-select: none;\\n user-select: none;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item {\\n display: block;\\n color: #222;\\n font-size: 12px;\\n line-height: 20px;\\n text-decoration: none;\\n padding: 0 12px;\\n border-top: 1px solid transparent;\\n border-bottom: 1px solid transparent;\\n cursor: default;\\n outline: none;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item-disabled {\\n opacity: 0.5;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item.over {\\n background-color: #f4f4f4;\\n border-top: 1px solid #f0f0f0;\\n border-bottom: 1px solid #f0f0f0;\\n}\\n\\n.leaflet-contextmenu a.leaflet-contextmenu-item-disabled.over {\\n background-color: inherit;\\n border-top: 1px solid transparent;\\n border-bottom: 1px solid transparent;\\n}\\n\\n.leaflet-contextmenu-icon {\\n margin: 2px 8px 0 0;\\n width: 16px;\\n height: 16px;\\n float: left;\\n border: 0;\\n}\\n\\n.leaflet-contextmenu-separator {\\n border-bottom: 1px solid #ccc;\\n margin: 5px 0;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\n/* harmony default export */ __webpack_exports__[\"default\"] = (___CSS_LOADER_EXPORT___);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbmV4dC9kaXN0L2J1aWxkL3dlYnBhY2svbG9hZGVycy9jc3MtbG9hZGVyL3NyYy9pbmRleC5qcz8/cnVsZVNldFsxXS5ydWxlc1s2XS5vbmVPZlsxMl0udXNlWzFdIS4vbm9kZV9tb2R1bGVzL25leHQvZGlzdC9idWlsZC93ZWJwYWNrL2xvYWRlcnMvcG9zdGNzcy1sb2FkZXIvc3JjL2luZGV4LmpzPz9ydWxlU2V0WzFdLnJ1bGVzWzZdLm9uZU9mWzEyXS51c2VbMl0hLi9ub2RlX21vZHVsZXMvbGVhZmxldC1jb250ZXh0bWVudS9kaXN0L2xlYWZsZXQuY29udGV4dG1lbnUuY3NzIiwibWFwcGluZ3MiOiI7OztBQUFBO0FBQzhHO0FBQzlHLDhCQUE4QixxR0FBMkI7QUFDekQ7QUFDQSxnRUFBZ0Usb0JBQW9CLDRDQUE0Qyx5QkFBeUIscUJBQXFCLDZCQUE2QixzQkFBc0IsZ0NBQWdDLDZCQUE2Qix3QkFBd0IsR0FBRyxxREFBcUQscUJBQXFCLGtCQUFrQixzQkFBc0Isd0JBQXdCLDRCQUE0QixzQkFBc0Isd0NBQXdDLDJDQUEyQyxzQkFBc0Isb0JBQW9CLEdBQUcsOERBQThELG1CQUFtQixHQUFHLDBEQUEwRCxnQ0FBZ0Msb0NBQW9DLHVDQUF1QyxHQUFHLG1FQUFtRSxnQ0FBZ0Msd0NBQXdDLDJDQUEyQyxHQUFHLCtCQUErQiwwQkFBMEIsa0JBQWtCLG1CQUFtQixrQkFBa0IsZ0JBQWdCLEdBQUcsb0NBQW9DLG9DQUFvQyxvQkFBb0IsR0FBRyxTQUFTLDhIQUE4SCxVQUFVLFlBQVksYUFBYSxXQUFXLFlBQVksV0FBVyxZQUFZLGFBQWEsYUFBYSxPQUFPLEtBQUssVUFBVSxVQUFVLFVBQVUsWUFBWSxhQUFhLFdBQVcsWUFBWSxhQUFhLFdBQVcsVUFBVSxPQUFPLEtBQUssVUFBVSxPQUFPLEtBQUssWUFBWSxhQUFhLGFBQWEsT0FBTyxLQUFLLFlBQVksYUFBYSxhQUFhLE9BQU8sS0FBSyxZQUFZLFdBQVcsVUFBVSxVQUFVLFVBQVUsTUFBTSxLQUFLLFlBQVksV0FBVyxnREFBZ0Qsb0JBQW9CLDRDQUE0QyxpQ0FBaUMseUJBQXlCLHFCQUFxQiw2QkFBNkIsc0JBQXNCLGdDQUFnQyw2QkFBNkIsd0JBQXdCLEdBQUcscURBQXFELHFCQUFxQixrQkFBa0Isc0JBQXNCLHdCQUF3Qiw0QkFBNEIsc0JBQXNCLHdDQUF3QywyQ0FBMkMsc0JBQXNCLG9CQUFvQixHQUFHLDhEQUE4RCxtQkFBbUIsR0FBRywwREFBMEQsZ0NBQWdDLG9DQUFvQyx1Q0FBdUMsR0FBRyxtRUFBbUUsZ0NBQWdDLHdDQUF3QywyQ0FBMkMsR0FBRywrQkFBK0IsMEJBQTBCLGtCQUFrQixtQkFBbUIsa0JBQWtCLGdCQUFnQixHQUFHLG9DQUFvQyxvQ0FBb0Msb0JBQW9CLEdBQUcscUJBQXFCO0FBQ3pvRztBQUNBLCtEQUFlLHVCQUF1QixFQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vX05fRS8uL25vZGVfbW9kdWxlcy9sZWFmbGV0LWNvbnRleHRtZW51L2Rpc3QvbGVhZmxldC5jb250ZXh0bWVudS5jc3M/ODk3MiJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJbXBvcnRzXG5pbXBvcnQgX19fQ1NTX0xPQURFUl9BUElfSU1QT1JUX19fIGZyb20gXCIuLi8uLi9uZXh0L2Rpc3QvYnVpbGQvd2VicGFjay9sb2FkZXJzL2Nzcy1sb2FkZXIvc3JjL3J1bnRpbWUvYXBpLmpzXCI7XG52YXIgX19fQ1NTX0xPQURFUl9FWFBPUlRfX18gPSBfX19DU1NfTE9BREVSX0FQSV9JTVBPUlRfX18odHJ1ZSk7XG4vLyBNb2R1bGVcbl9fX0NTU19MT0FERVJfRVhQT1JUX19fLnB1c2goW21vZHVsZS5pZCwgXCIubGVhZmxldC1jb250ZXh0bWVudSB7XFxuICAgIGRpc3BsYXk6IG5vbmU7XFxuICAgIGJveC1zaGFkb3c6IDAgMXB4IDdweCByZ2JhKDAsMCwwLDAuNCk7XFxuICAgIGJvcmRlci1yYWRpdXM6IDRweDtcXG4gICAgcGFkZGluZzogNHB4IDA7XFxuICAgIGJhY2tncm91bmQtY29sb3I6ICNmZmY7XFxuICAgIGN1cnNvcjogZGVmYXVsdDtcXG4gICAgLXdlYmtpdC11c2VyLXNlbGVjdDogbm9uZTtcXG4gICAgLW1vei11c2VyLXNlbGVjdDogbm9uZTtcXG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtIHtcXG4gICAgZGlzcGxheTogYmxvY2s7XFxuICAgIGNvbG9yOiAjMjIyO1xcbiAgICBmb250LXNpemU6IDEycHg7XFxuICAgIGxpbmUtaGVpZ2h0OiAyMHB4O1xcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XFxuICAgIHBhZGRpbmc6IDAgMTJweDtcXG4gICAgYm9yZGVyLXRvcDogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xcbiAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XFxuICAgIGN1cnNvcjogZGVmYXVsdDtcXG4gICAgb3V0bGluZTogbm9uZTtcXG59XFxuXFxuLmxlYWZsZXQtY29udGV4dG1lbnUgYS5sZWFmbGV0LWNvbnRleHRtZW51LWl0ZW0tZGlzYWJsZWQge1xcbiAgICBvcGFjaXR5OiAwLjU7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtLm92ZXIge1xcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjRmNGY0O1xcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgI2YwZjBmMDtcXG4gICAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNmMGYwZjA7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtLWRpc2FibGVkLm92ZXIge1xcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiBpbmhlcml0O1xcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XFxuICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcXG59XFxuXFxuLmxlYWZsZXQtY29udGV4dG1lbnUtaWNvbiB7XFxuICAgIG1hcmdpbjogMnB4IDhweCAwIDA7XFxuICAgIHdpZHRoOiAxNnB4O1xcbiAgICBoZWlnaHQ6IDE2cHg7XFxuICAgIGZsb2F0OiBsZWZ0O1xcbiAgICBib3JkZXI6IDA7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51LXNlcGFyYXRvciB7XFxuICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAjY2NjO1xcbiAgICBtYXJnaW46IDVweCAwO1xcbn1cXG5cIiwgXCJcIix7XCJ2ZXJzaW9uXCI6MyxcInNvdXJjZXNcIjpbXCJ3ZWJwYWNrOi8vbm9kZV9tb2R1bGVzL2xlYWZsZXQtY29udGV4dG1lbnUvZGlzdC9sZWFmbGV0LmNvbnRleHRtZW51LmNzc1wiXSxcIm5hbWVzXCI6W10sXCJtYXBwaW5nc1wiOlwiQUFBQTtJQUNJLGFBQWE7SUFDYixxQ0FBcUM7SUFFckMsa0JBQWtCO0lBQ2xCLGNBQWM7SUFDZCxzQkFBc0I7SUFDdEIsZUFBZTtJQUNmLHlCQUF5QjtJQUN6QixzQkFBc0I7SUFDdEIsaUJBQWlCO0FBQ3JCOztBQUVBO0lBQ0ksY0FBYztJQUNkLFdBQVc7SUFDWCxlQUFlO0lBQ2YsaUJBQWlCO0lBQ2pCLHFCQUFxQjtJQUNyQixlQUFlO0lBQ2YsaUNBQWlDO0lBQ2pDLG9DQUFvQztJQUNwQyxlQUFlO0lBQ2YsYUFBYTtBQUNqQjs7QUFFQTtJQUNJLFlBQVk7QUFDaEI7O0FBRUE7SUFDSSx5QkFBeUI7SUFDekIsNkJBQTZCO0lBQzdCLGdDQUFnQztBQUNwQzs7QUFFQTtJQUNJLHlCQUF5QjtJQUN6QixpQ0FBaUM7SUFDakMsb0NBQW9DO0FBQ3hDOztBQUVBO0lBQ0ksbUJBQW1CO0lBQ25CLFdBQVc7SUFDWCxZQUFZO0lBQ1osV0FBVztJQUNYLFNBQVM7QUFDYjs7QUFFQTtJQUNJLDZCQUE2QjtJQUM3QixhQUFhO0FBQ2pCXCIsXCJzb3VyY2VzQ29udGVudFwiOltcIi5sZWFmbGV0LWNvbnRleHRtZW51IHtcXG4gICAgZGlzcGxheTogbm9uZTtcXG4gICAgYm94LXNoYWRvdzogMCAxcHggN3B4IHJnYmEoMCwwLDAsMC40KTtcXG4gICAgLXdlYmtpdC1ib3JkZXItcmFkaXVzOiA0cHg7XFxuICAgIGJvcmRlci1yYWRpdXM6IDRweDtcXG4gICAgcGFkZGluZzogNHB4IDA7XFxuICAgIGJhY2tncm91bmQtY29sb3I6ICNmZmY7XFxuICAgIGN1cnNvcjogZGVmYXVsdDtcXG4gICAgLXdlYmtpdC11c2VyLXNlbGVjdDogbm9uZTtcXG4gICAgLW1vei11c2VyLXNlbGVjdDogbm9uZTtcXG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtIHtcXG4gICAgZGlzcGxheTogYmxvY2s7XFxuICAgIGNvbG9yOiAjMjIyO1xcbiAgICBmb250LXNpemU6IDEycHg7XFxuICAgIGxpbmUtaGVpZ2h0OiAyMHB4O1xcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XFxuICAgIHBhZGRpbmc6IDAgMTJweDtcXG4gICAgYm9yZGVyLXRvcDogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xcbiAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XFxuICAgIGN1cnNvcjogZGVmYXVsdDtcXG4gICAgb3V0bGluZTogbm9uZTtcXG59XFxuXFxuLmxlYWZsZXQtY29udGV4dG1lbnUgYS5sZWFmbGV0LWNvbnRleHRtZW51LWl0ZW0tZGlzYWJsZWQge1xcbiAgICBvcGFjaXR5OiAwLjU7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtLm92ZXIge1xcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjRmNGY0O1xcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgI2YwZjBmMDtcXG4gICAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNmMGYwZjA7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51IGEubGVhZmxldC1jb250ZXh0bWVudS1pdGVtLWRpc2FibGVkLm92ZXIge1xcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiBpbmhlcml0O1xcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XFxuICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcXG59XFxuXFxuLmxlYWZsZXQtY29udGV4dG1lbnUtaWNvbiB7XFxuICAgIG1hcmdpbjogMnB4IDhweCAwIDA7XFxuICAgIHdpZHRoOiAxNnB4O1xcbiAgICBoZWlnaHQ6IDE2cHg7XFxuICAgIGZsb2F0OiBsZWZ0O1xcbiAgICBib3JkZXI6IDA7XFxufVxcblxcbi5sZWFmbGV0LWNvbnRleHRtZW51LXNlcGFyYXRvciB7XFxuICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAjY2NjO1xcbiAgICBtYXJnaW46IDVweCAwO1xcbn1cXG5cIl0sXCJzb3VyY2VSb290XCI6XCJcIn1dKTtcbi8vIEV4cG9ydHNcbmV4cG9ydCBkZWZhdWx0IF9fX0NTU19MT0FERVJfRVhQT1JUX19fO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css\n")); + +/***/ }), + /***/ "./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet/dist/leaflet.css": /*!*****************************************************************************************************************************************************************************************************************************************************************************!*\ !*** ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet/dist/leaflet.css ***! @@ -29,6 +50,16 @@ eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* har /***/ }), +/***/ "./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css": +/*!***********************************************************************!*\ + !*** ./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css ***! + \***********************************************************************/ +/***/ (function(module, __unused_webpack_exports, __webpack_require__) { + +eval(__webpack_require__.ts("var api = __webpack_require__(/*! !../../next/dist/build/webpack/loaders/next-style-loader/runtime/injectStylesIntoStyleTag.js */ \"./node_modules/next/dist/build/webpack/loaders/next-style-loader/runtime/injectStylesIntoStyleTag.js\");\n var content = __webpack_require__(/*! !!../../next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!../../next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./leaflet.contextmenu.css */ \"./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[1]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[6].oneOf[12].use[2]!./node_modules/leaflet-contextmenu/dist/leaflet.contextmenu.css\");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === 'string') {\n content = [[module.id, content, '']];\n }\n\nvar options = {};\n\noptions.insert = function(element) {\n // By default, style-loader injects CSS into the bottom\n // of . This causes ordering problems between dev\n // and prod. To fix this, we render a