Files
nodeMap/.next/server/components_MapComponent_js.js

35 lines
68 KiB
JavaScript

"use strict";
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
exports.id = "components_MapComponent_js";
exports.ids = ["components_MapComponent_js"];
exports.modules = {
/***/ "./components/MapComponent.js":
/*!************************************!*\
!*** ./components/MapComponent.js ***!
\************************************/
/***/ ((__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/* 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/* harmony import */ var _config_config_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../config/config.js */ \"./config/config.js\");\n// components/MapComponent.js\n\n\n\n\n\n\n\nconst MapComponent = ({ locations, onLocationUpdate })=>{\n const mapRef = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(null); // Referenz auf das DIV-Element der Karte\n const [map, setMap] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null); // Zustand der Karteninstanz\n const [online, setOnline] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(navigator.onLine); // Zustand der Internetverbindung\n const [GisStationsStaticDistrict, setGisStationsStaticDistrict] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]); // Zustand für statische Daten\n const [dataStatus, setDataStatus] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]); // Zustand für Statusdaten\n const [dataIcons, setDataIcons] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]); // Zustand für Icons\n const [dataSystem, setDataSystem] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]); // Zustand für Systemdaten\n // Konstanten für die URLs\n const mapGisStationsStaticDistrictUrl = _config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapGisStationsStaticDistrictUrl;\n const mapDataStatusUrl = _config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataStatusUrl;\n const mapDataIconUrl = _config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataIconUrl;\n const mapDataSystemUrl = _config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataSystemUrl;\n console.log(\"GisStationsStaticDistrict 1 :\", GisStationsStaticDistrict);\n console.log(\"map:\", map);\n //------------------------------------------\n // API-Daten laden für GisStationsStaticDistrict\n //http://10.10.0.13/talas5/ClientData/WebServiceMap.asmx/GisStationsStaticDistrict?idMap=10&idUser=485\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n const fetchData = async ()=>{\n try {\n console.log(\"Datenabruf gestartet...\");\n const response = await fetch(_config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapGisStationsStaticDistrictUrl);\n const jsonResponse = await response.json();\n // Prüfen, ob die Antwort das erwartete Format hat und Daten enthält\n if (jsonResponse && jsonResponse.Points) {\n console.log(\"GisStationsStaticDistrict geladen:\", jsonResponse.Points);\n setGisStationsStaticDistrict(jsonResponse.Points); // Direkter Zugriff auf 'Points'\n } else {\n console.error('Erwartete Daten im \"Points\"-Array nicht gefunden', jsonResponse);\n setGisStationsStaticDistrict([]);\n }\n } catch (error) {\n console.error(\"Fehler beim Laden der Daten: \", error);\n setGisStationsStaticDistrict([]);\n }\n };\n fetchData();\n }, []); // Dependency-Array ist leer, um den Effekt nur beim Mount auszuführen\n //------------------------------------------\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n // Prüfen der Internetverbindung beim Start\n console.log(\"Pr\\xfcfen der Internetverbindung...\");\n checkInternet();\n // Asynchrones Laden der Kartendaten beim Initialisieren der Komponente\n const fetchData = async ()=>{\n try {\n console.log(\"Datenabruf gestartet...\");\n const responses = await Promise.all([\n fetch(_config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapGisStationsStaticDistrictUrl).then((res)=>res.json()),\n fetch(_config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataStatusUrl).then((res)=>res.json()),\n fetch(_config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataIconUrl).then((res)=>res.json()),\n fetch(_config_config_js__WEBPACK_IMPORTED_MODULE_6__.mapDataSystemUrl).then((res)=>res.json())\n ]);\n console.log(\"Daten erfolgreich geladen.\");\n setGisStationsStaticDistrict(responses[0].Points);\n setDataStatus(responses[1].Statis);\n setDataIcons(responses[2].List);\n setDataSystem(responses[3].Systems.filter((system)=>system.Allow === 1));\n } catch (error) {\n console.error(\"Fehler beim Laden der Daten: \", error);\n }\n };\n fetchData();\n }, []); // Leeres Abhängigkeitsarray, um nur beim ersten Mount zu laden\n const offlineTileLayer = \"../TileMap/mapTiles/{z}/{x}/{y}.png\";\n const onlineTileLayer = \"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\";\n // Create map layers\n const TALAS = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const ECI = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const ULAF = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const GSMModem = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const CiscoRouter = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const WAGO = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const Siemens = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const OTDR = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const WDM = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const GMA = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const Sonstige = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n const TALASICL = new (leaflet__WEBPACK_IMPORTED_MODULE_2___default().layerGroup)();\n let initialMap = [];\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n console.log(\"Server URL from config:\", _config_config_js__WEBPACK_IMPORTED_MODULE_6__.serverURL);\n if (false) {}\n }, []);\n // Funktionen zur Überwachung der Internetverbindung\n const checkInternet = ()=>{\n console.log(\"Checking internet connectivity...\");\n fetch(\"https://tile.openstreetmap.org/1/1/1.png\", {\n method: \"HEAD\"\n }).then((response)=>setOnline(response.ok)).catch(()=>setOnline(false));\n };\n // Initialisiere die Karte\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (mapRef.current && !map) {\n initialMap = leaflet__WEBPACK_IMPORTED_MODULE_2___default().map(mapRef.current, {\n center: [\n 53.111111,\n 8.4625\n ],\n zoom: 10,\n layers: [\n TALAS,\n ECI,\n ULAF,\n GSMModem,\n CiscoRouter,\n WAGO,\n Siemens,\n OTDR,\n WDM,\n GMA,\n Sonstige,\n TALASICL\n ],\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 leaflet__WEBPACK_IMPORTED_MODULE_2___default().tileLayer(online ? onlineTileLayer : offlineTileLayer, {\n attribution: '&copy; <a href=\"https://www.openstreetmap.org/copyright\">OpenStreetMap</a> contributors'\n }).addTo(initialMap);\n setMap(initialMap);\n }\n }, [\n mapRef,\n map\n ]);\n // Handle online/offline status\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n window.addEventListener(\"online\", checkInternet);\n window.addEventListener(\"offline\", checkInternet);\n return ()=>{\n window.removeEventListener(\"online\", checkInternet);\n window.removeEventListener(\"offline\", checkInternet);\n };\n }, []);\n // Update map layers based on online status\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (map) {\n const newLayer = leaflet__WEBPACK_IMPORTED_MODULE_2___default().tileLayer(online ? onlineTileLayer : offlineTileLayer, {\n minZoom: 7,\n maxZoom: online ? 19 : 14,\n attribution: 'Map data \\xa9 <a href=\"https://www.openstreetmap.org/copyright\">OpenStreetMap</a> contributors'\n });\n map.eachLayer((layer)=>{\n if (layer instanceof (leaflet__WEBPACK_IMPORTED_MODULE_2___default().TileLayer)) {\n map.removeLayer(layer);\n }\n });\n newLayer.addTo(map);\n }\n }, [\n online,\n map\n ]);\n // Marker handling\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n // Remove old markers\n if (map) {\n map.eachLayer((layer)=>{\n if (layer instanceof (leaflet__WEBPACK_IMPORTED_MODULE_2___default().Marker)) {\n map.removeLayer(layer);\n }\n });\n // Add new markers\n locations.forEach((location)=>{\n const { latitude, longitude } = parsePoint(location.position);\n const marker = leaflet__WEBPACK_IMPORTED_MODULE_2___default().marker([\n latitude,\n longitude\n ], {\n icon: leaflet__WEBPACK_IMPORTED_MODULE_2___default().icon({\n iconUrl: \"/location.svg\",\n iconSize: [\n 34,\n 34\n ],\n iconAnchor: [\n 17,\n 34\n ],\n popupAnchor: [\n 0,\n -34\n ]\n }),\n draggable: true,\n id: location.idPoi\n });\n marker.bindPopup(`<b>${location.description || \"Unbekannt\"}</b><br>Type: ${location.idPoiTyp || \"N/A\"}<br>Lat: ${latitude.toFixed(5)}, Lng: ${longitude.toFixed(5)}`);\n marker.on(\"dragend\", function(e) {\n const newLat = e.target.getLatLng().lat;\n const newLng = e.target.getLatLng().lng;\n const markerId = e.target.options.id;\n updateLocationInDatabase(markerId, newLat, newLng).then(()=>{\n onLocationUpdate(markerId, newLat, newLng);\n });\n });\n marker.addTo(map);\n });\n }\n }, [\n map,\n locations,\n onLocationUpdate\n ]);\n //------------------------------------------\n function parsePoint(pointString) {\n const match = pointString.match(/POINT\\s*\\((\\d+(\\.\\d+)?)\\s+(\\d+(\\.\\d+)?)\\)/);\n if (match) {\n return {\n longitude: parseFloat(match[1]),\n latitude: parseFloat(match[3])\n };\n } else {\n // Handle the error or return a default/fallback value\n console.error(\"Invalid POINT format:\", pointString);\n return null; // Oder eine sinnvolle Standardantwort\n }\n }\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 initialMap.flyTo(e.latlng, 12);\n };\n const zoomOut = (e)=>{\n fly();\n };\n const centerHere = (e)=>{\n initialMap.panTo(e.latlng);\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 // Ensure this function is only called when map is initialized and available\n const showAddStationPopup = (e)=>{\n if (!initialMap) {\n console.log(\"Map is not initialized.\");\n return;\n }\n const popupContent = leaflet__WEBPACK_IMPORTED_MODULE_2___default().DomUtil.create(\"div\");\n popupContent.innerHTML = `\r\n <form id=\"addStationForm\" class=\"m-0 p-2 w-full\">\r\n <div class=\"flex items-center mb-4\"> \r\n <label for=\"name\" class=\"block mr-2 flex-none\">Name:</label>\r\n <input\r\n type=\"text\"\r\n id=\"name\"\r\n name=\"name\"\r\n placeholder=\"Name der Station\"\r\n class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n />\r\n </div>\r\n \r\n <div class=\"flex items-center mb-4\"> \r\n <label for=\"type\" class=\"block mr-3 flex-none\">Type:</label>\r\n <input\r\n type=\"text\"\r\n id=\"type\"\r\n name=\"type\"\r\n placeholder=\"Typ der Station\"\r\n class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n />\r\n </div>\r\n \r\n <div class=\"flex items-center mb-4\">\r\n <label for=\"lat\" class=\"block mr-2 flex-none\">Breitengrad:</label>\r\n <input\r\n type=\"text\"\r\n id=\"lat\"\r\n name=\"lat\"\r\n value=\"${e.latlng.lat.toFixed(5)}\"\r\n readonly\r\n class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n />\r\n </div>\r\n \r\n <div class=\"flex items-center mb-4\"> \r\n <label for=\"lng\" class=\"block mr-2 flex-none\">Längengrad:</label>\r\n <input\r\n type=\"text\"\r\n id=\"lng\"\r\n name=\"lng\"\r\n value=\"${e.latlng.lng.toFixed(5)}\"\r\n readonly\r\n class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n />\r\n </div>\r\n \r\n <button\r\n type=\"submit\"\r\n class=\"bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-4 rounded w-full\"\r\n >\r\n Station hinzufügen\r\n </button>\r\n</form>\r\n `;\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().popup().setLatLng(e.latlng).setContent(popupContent).openOn(initialMap);\n // Attach event listener here\n leaflet__WEBPACK_IMPORTED_MODULE_2___default().DomEvent.on(popupContent, \"submit\", handleSubmit);\n };\n /*\r\n const handleSubmit = (event) => {\r\n event.preventDefault();\r\n const form = event.target;\r\n const data = {\r\n name: form.name.value,\r\n type: form.type.value,\r\n latitude: form.lat.value,\r\n longitude: form.lng.value,\r\n };\r\n\r\n onAddLocation(name, type, lat, lng);\r\n console.log(\"Name: \", name, \"Type: \", type, \"Lat: \", lat, \"Lng: \", lng);\r\n map.closePopup();\r\n };\r\n*/ // Funktion zum Hinzufügen eines neuen Standorts\n async function handleSubmit(event) {\n event.preventDefault();\n const form = event.target;\n const data = {\n name: form.name.value,\n type: form.type.value,\n latitude: form.lat.value,\n longitude: form.lng.value\n };\n try {\n const response = await fetch(\"/api/addLocation\", {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify(data)\n });\n const result = await response.json();\n if (response.ok) {\n console.log(\"Standort hinzugef\\xfcgt:\", result);\n alert(\"Standort erfolgreich hinzugef\\xfcgt!\");\n form.reset(); // Formular zurücksetzen\n // Hier könntest du weitere Aktionen durchführen, wie das Schließen des Popups oder das Aktualisieren der Marker auf der Karte\n } else {\n throw new Error(result.error || \"Ein unbekannter Fehler ist aufgetreten.\");\n }\n } catch (error) {\n console.error(\"Fehler beim Hinzuf\\xfcgen des Standorts:\", error);\n alert(error.message);\n }\n }\n function fly(stationValue) {\n var x = 51.41321407879154;\n var y = 7.739617925303934;\n var zoom = 7;\n /* for (var i = 0; i < GisStationsStaticDistrictlength; i++) {\r\n var gisStatics = GisStationsStaticDistrict[i];\r\n if (stationValue === gisStatics.Area_Name) {\r\n //console.log(gisStatics.X+\",\"+gisStatics.Y);\r\n x = gisStatics.X;\r\n y = gisStatics.Y;\r\n }\r\n }\r\n if (y === 7.739617925303934) {\r\n zoom = 8;\r\n } */ initialMap.flyTo([\n x,\n y\n ], zoom);\n /* var popup = new L.Popup();\r\n oms.addListener(\"click\", function (marker) {\r\n popup.setContent(marker.desc);\r\n popup.setLatLng(marker.getLatLng());\r\n map.openPopup(popup);\r\n });\r\n\r\n for (var i = 0; i < window.mapData.length; i++) {\r\n var datum = window.mapData[i];\r\n var loc = new L.LatLng(datum.lat, datum.lon);\r\n var marker = new L.Marker(loc);\r\n marker.desc = datum.d;\r\n map.addLayer(marker);\r\n //oms.addMarker(marker); // <-- here\r\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\\\\16.04.2024\\\\wwwrootTalas5NodeMap\\\\components\\\\MapComponent.js\",\n lineNumber: 493,\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":["// components/MapComponent.js\r\nimport 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\nimport * as config from \"../config/config.js\";\r\nconst MapComponent = ({ locations, onLocationUpdate }) => {\r\n  const mapRef = useRef(null); // Referenz auf das DIV-Element der Karte\r\n  const [map, setMap] = useState(null); // Zustand der Karteninstanz\r\n  const [online, setOnline] = useState(navigator.onLine); // Zustand der Internetverbindung\r\n  const [GisStationsStaticDistrict, setGisStationsStaticDistrict] = useState(\r\n    []\r\n  ); // Zustand für statische Daten\r\n  const [dataStatus, setDataStatus] = useState([]); // Zustand für Statusdaten\r\n  const [dataIcons, setDataIcons] = useState([]); // Zustand für Icons\r\n  const [dataSystem, setDataSystem] = useState([]); // Zustand für Systemdaten\r\n\r\n  // Konstanten für die URLs\r\n  const mapGisStationsStaticDistrictUrl =\r\n    config.mapGisStationsStaticDistrictUrl;\r\n  const mapDataStatusUrl = config.mapDataStatusUrl;\r\n  const mapDataIconUrl = config.mapDataIconUrl;\r\n  const mapDataSystemUrl = config.mapDataSystemUrl;\r\n\r\n  console.log(\"GisStationsStaticDistrict 1 :\", GisStationsStaticDistrict);\r\n  console.log(\"map:\", map);\r\n  //------------------------------------------\r\n  // API-Daten laden für GisStationsStaticDistrict\r\n  //http://10.10.0.13/talas5/ClientData/WebServiceMap.asmx/GisStationsStaticDistrict?idMap=10&idUser=485\r\n  useEffect(() => {\r\n    const fetchData = async () => {\r\n      try {\r\n        console.log(\"Datenabruf gestartet...\");\r\n        const response = await fetch(config.mapGisStationsStaticDistrictUrl);\r\n        const jsonResponse = await response.json();\r\n\r\n        // Prüfen, ob die Antwort das erwartete Format hat und Daten enthält\r\n        if (jsonResponse && jsonResponse.Points) {\r\n          console.log(\r\n            \"GisStationsStaticDistrict geladen:\",\r\n            jsonResponse.Points\r\n          );\r\n          setGisStationsStaticDistrict(jsonResponse.Points); // Direkter Zugriff auf 'Points'\r\n        } else {\r\n          console.error(\r\n            'Erwartete Daten im \"Points\"-Array nicht gefunden',\r\n            jsonResponse\r\n          );\r\n          setGisStationsStaticDistrict([]);\r\n        }\r\n      } catch (error) {\r\n        console.error(\"Fehler beim Laden der Daten: \", error);\r\n        setGisStationsStaticDistrict([]);\r\n      }\r\n    };\r\n\r\n    fetchData();\r\n  }, []); // Dependency-Array ist leer, um den Effekt nur beim Mount auszuführen\r\n\r\n  //------------------------------------------\r\n  useEffect(() => {\r\n    // Prüfen der Internetverbindung beim Start\r\n    console.log(\"Prüfen der Internetverbindung...\");\r\n    checkInternet();\r\n\r\n    // Asynchrones Laden der Kartendaten beim Initialisieren der Komponente\r\n    const fetchData = async () => {\r\n      try {\r\n        console.log(\"Datenabruf gestartet...\");\r\n        const responses = await Promise.all([\r\n          fetch(config.mapGisStationsStaticDistrictUrl).then((res) =>\r\n            res.json()\r\n          ),\r\n          fetch(config.mapDataStatusUrl).then((res) => res.json()),\r\n          fetch(config.mapDataIconUrl).then((res) => res.json()),\r\n          fetch(config.mapDataSystemUrl).then((res) => res.json()),\r\n        ]);\r\n        console.log(\"Daten erfolgreich geladen.\");\r\n        setGisStationsStaticDistrict(responses[0].Points);\r\n        setDataStatus(responses[1].Statis);\r\n        setDataIcons(responses[2].List);\r\n        setDataSystem(\r\n          responses[3].Systems.filter((system) => system.Allow === 1)\r\n        );\r\n      } catch (error) {\r\n        console.error(\"Fehler beim Laden der Daten: \", error);\r\n      }\r\n    };\r\n\r\n    fetchData();\r\n  }, []); // Leeres Abhängigkeitsarray, um nur beim ersten Mount zu laden\r\n\r\n  const offlineTileLayer = \"../TileMap/mapTiles/{z}/{x}/{y}.png\";\r\n  const onlineTileLayer = \"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\";\r\n  // Create map layers\r\n  const TALAS = new L.layerGroup();\r\n  const ECI = new L.layerGroup();\r\n  const ULAF = new L.layerGroup();\r\n  const GSMModem = new L.layerGroup();\r\n  const CiscoRouter = new L.layerGroup();\r\n  const WAGO = new L.layerGroup();\r\n  const Siemens = new L.layerGroup();\r\n  const OTDR = new L.layerGroup();\r\n  const WDM = new L.layerGroup();\r\n  const GMA = new L.layerGroup();\r\n  const Sonstige = new L.layerGroup();\r\n  const TALASICL = new L.layerGroup();\r\n\r\n  let initialMap = [];\r\n\r\n  useEffect(() => {\r\n    console.log(\"Server URL from config:\", config.serverURL);\r\n    if (typeof window !== \"undefined\") {\r\n      console.log(\"Window height from config:\", config.windowHeight);\r\n    }\r\n  }, []);\r\n\r\n  // Funktionen zur Überwachung der Internetverbindung\r\n  const checkInternet = () => {\r\n    console.log(\"Checking internet connectivity...\");\r\n    fetch(\"https://tile.openstreetmap.org/1/1/1.png\", { method: \"HEAD\" })\r\n      .then((response) => setOnline(response.ok))\r\n      .catch(() => setOnline(false));\r\n  };\r\n  // Initialisiere die Karte\r\n  useEffect(() => {\r\n    if (mapRef.current && !map) {\r\n      initialMap = L.map(mapRef.current, {\r\n        center: [53.111111, 8.4625],\r\n        zoom: 10,\r\n        layers: [\r\n          TALAS,\r\n          ECI,\r\n          ULAF,\r\n          GSMModem,\r\n          CiscoRouter,\r\n          WAGO,\r\n          Siemens,\r\n          OTDR,\r\n          WDM,\r\n          GMA,\r\n          Sonstige,\r\n          TALASICL,\r\n        ],\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      L.tileLayer(online ? onlineTileLayer : offlineTileLayer, {\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  // Handle online/offline status\r\n  useEffect(() => {\r\n    window.addEventListener(\"online\", checkInternet);\r\n    window.addEventListener(\"offline\", checkInternet);\r\n    return () => {\r\n      window.removeEventListener(\"online\", checkInternet);\r\n      window.removeEventListener(\"offline\", checkInternet);\r\n    };\r\n  }, []);\r\n\r\n  // Update map layers based on online status\r\n  useEffect(() => {\r\n    if (map) {\r\n      const newLayer = L.tileLayer(\r\n        online ? onlineTileLayer : offlineTileLayer,\r\n        {\r\n          minZoom: 7,\r\n          maxZoom: online ? 19 : 14,\r\n          attribution:\r\n            'Map data © <a href=\"https://www.openstreetmap.org/copyright\">OpenStreetMap</a> contributors',\r\n        }\r\n      );\r\n\r\n      map.eachLayer((layer) => {\r\n        if (layer instanceof L.TileLayer) {\r\n          map.removeLayer(layer);\r\n        }\r\n      });\r\n\r\n      newLayer.addTo(map);\r\n    }\r\n  }, [online, map]);\r\n\r\n  // Marker handling\r\n  useEffect(() => {\r\n    // Remove old markers\r\n    if (map) {\r\n      map.eachLayer((layer) => {\r\n        if (layer instanceof L.Marker) {\r\n          map.removeLayer(layer);\r\n        }\r\n      });\r\n\r\n      // Add new markers\r\n      locations.forEach((location) => {\r\n        const { latitude, longitude } = parsePoint(location.position);\r\n        const marker = L.marker([latitude, longitude], {\r\n          icon: L.icon({\r\n            iconUrl: \"/location.svg\",\r\n            iconSize: [34, 34],\r\n            iconAnchor: [17, 34],\r\n            popupAnchor: [0, -34],\r\n          }),\r\n          draggable: true,\r\n          id: location.idPoi,\r\n        });\r\n\r\n        marker.bindPopup(\r\n          `<b>${location.description || \"Unbekannt\"}</b><br>Type: ${location.idPoiTyp || \"N/A\"}<br>Lat: ${latitude.toFixed(5)}, Lng: ${longitude.toFixed(5)}`\r\n        );\r\n\r\n        marker.on(\"dragend\", function (e) {\r\n          const newLat = e.target.getLatLng().lat;\r\n          const newLng = e.target.getLatLng().lng;\r\n          const markerId = e.target.options.id;\r\n          updateLocationInDatabase(markerId, newLat, newLng).then(() => {\r\n            onLocationUpdate(markerId, newLat, newLng);\r\n          });\r\n        });\r\n\r\n        marker.addTo(map);\r\n      });\r\n    }\r\n  }, [map, locations, onLocationUpdate]);\r\n\r\n  //------------------------------------------\r\n  function parsePoint(pointString) {\r\n    const match = pointString.match(\r\n      /POINT\\s*\\((\\d+(\\.\\d+)?)\\s+(\\d+(\\.\\d+)?)\\)/\r\n    );\r\n    if (match) {\r\n      return {\r\n        longitude: parseFloat(match[1]),\r\n        latitude: parseFloat(match[3]), // Achtung: Index 3 für die zweite Koordinate, wegen der Gruppe (\\.\\d+)?\r\n      };\r\n    } else {\r\n      // Handle the error or return a default/fallback value\r\n      console.error(\"Invalid POINT format:\", pointString);\r\n      return null; // Oder eine sinnvolle Standardantwort\r\n    }\r\n  }\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    initialMap.flyTo(e.latlng, 12);\r\n  };\r\n\r\n  const zoomOut = (e) => {\r\n    fly();\r\n  };\r\n  const centerHere = (e) => {\r\n    initialMap.panTo(e.latlng);\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  // Ensure this function is only called when map is initialized and available\r\n  const showAddStationPopup = (e) => {\r\n    if (!initialMap) {\r\n      console.log(\"Map is not initialized.\");\r\n      return;\r\n    }\r\n\r\n    const popupContent = L.DomUtil.create(\"div\");\r\n    popupContent.innerHTML = `\r\n  <form id=\"addStationForm\" class=\"m-0 p-2 w-full\">\r\n  <div class=\"flex items-center mb-4\">      \r\n    <label for=\"name\" class=\"block mr-2 flex-none\">Name:</label>\r\n    <input\r\n      type=\"text\"\r\n      id=\"name\"\r\n      name=\"name\"\r\n      placeholder=\"Name der Station\"\r\n      class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n    />\r\n  </div>\r\n  \r\n  <div class=\"flex items-center mb-4\">   \r\n    <label for=\"type\" class=\"block mr-3 flex-none\">Type:</label>\r\n    <input\r\n      type=\"text\"\r\n      id=\"type\"\r\n      name=\"type\"\r\n      placeholder=\"Typ der Station\"\r\n      class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n    />\r\n  </div>\r\n  \r\n  <div class=\"flex items-center mb-4\">\r\n    <label for=\"lat\" class=\"block mr-2 flex-none\">Breitengrad:</label>\r\n    <input\r\n      type=\"text\"\r\n      id=\"lat\"\r\n      name=\"lat\"\r\n      value=\"${e.latlng.lat.toFixed(5)}\"\r\n      readonly\r\n      class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n    />\r\n  </div>\r\n   \r\n  <div class=\"flex items-center mb-4\">   \r\n    <label for=\"lng\" class=\"block mr-2 flex-none\">Längengrad:</label>\r\n    <input\r\n      type=\"text\"\r\n      id=\"lng\"\r\n      name=\"lng\"\r\n      value=\"${e.latlng.lng.toFixed(5)}\"\r\n      readonly\r\n      class=\"block p-2 flex-grow border-2 border-gray-200 rounded-md text-sm\"\r\n    />\r\n  </div>\r\n  \r\n  <button\r\n    type=\"submit\"\r\n    class=\"bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-4 rounded w-full\"\r\n  >\r\n    Station hinzufügen\r\n  </button>\r\n</form>\r\n  `;\r\n\r\n    L.popup().setLatLng(e.latlng).setContent(popupContent).openOn(initialMap);\r\n\r\n    // Attach event listener here\r\n    L.DomEvent.on(popupContent, \"submit\", handleSubmit);\r\n  };\r\n\r\n  /*\r\n  const handleSubmit = (event) => {\r\n    event.preventDefault();\r\n    const form = event.target;\r\n    const data = {\r\n      name: form.name.value,\r\n      type: form.type.value,\r\n      latitude: form.lat.value,\r\n      longitude: form.lng.value,\r\n    };\r\n\r\n    onAddLocation(name, type, lat, lng);\r\n    console.log(\"Name: \", name, \"Type: \", type, \"Lat: \", lat, \"Lng: \", lng);\r\n    map.closePopup();\r\n  };\r\n*/\r\n  // Funktion zum Hinzufügen eines neuen Standorts\r\n  async function handleSubmit(event) {\r\n    event.preventDefault();\r\n    const form = event.target;\r\n    const data = {\r\n      name: form.name.value,\r\n      type: form.type.value,\r\n      latitude: form.lat.value,\r\n      longitude: form.lng.value,\r\n    };\r\n\r\n    try {\r\n      const response = await fetch(\"/api/addLocation\", {\r\n        method: \"POST\",\r\n        headers: {\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        body: JSON.stringify(data),\r\n      });\r\n\r\n      const result = await response.json();\r\n\r\n      if (response.ok) {\r\n        console.log(\"Standort hinzugefügt:\", result);\r\n        alert(\"Standort erfolgreich hinzugefügt!\");\r\n        form.reset(); // Formular zurücksetzen\r\n        // Hier könntest du weitere Aktionen durchführen, wie das Schließen des Popups oder das Aktualisieren der Marker auf der Karte\r\n      } else {\r\n        throw new Error(\r\n          result.error || \"Ein unbekannter Fehler ist aufgetreten.\"\r\n        );\r\n      }\r\n    } catch (error) {\r\n      console.error(\"Fehler beim Hinzufügen des Standorts:\", error);\r\n      alert(error.message);\r\n    }\r\n  }\r\n\r\n  function fly(stationValue) {\r\n    var x = 51.41321407879154;\r\n    var y = 7.739617925303934;\r\n    var zoom = 7;\r\n\r\n    /*  for (var i = 0; i < GisStationsStaticDistrictlength; i++) {\r\n      var gisStatics = GisStationsStaticDistrict[i];\r\n      if (stationValue === gisStatics.Area_Name) {\r\n        //console.log(gisStatics.X+\",\"+gisStatics.Y);\r\n        x = gisStatics.X;\r\n        y = gisStatics.Y;\r\n      }\r\n    }\r\n    if (y === 7.739617925303934) {\r\n      zoom = 8;\r\n    } */\r\n    initialMap.flyTo([x, y], zoom);\r\n\r\n    /* var popup = new L.Popup();\r\n    oms.addListener(\"click\", function (marker) {\r\n      popup.setContent(marker.desc);\r\n      popup.setLatLng(marker.getLatLng());\r\n      map.openPopup(popup);\r\n    });\r\n\r\n    for (var i = 0; i < window.mapData.length; i++) {\r\n      var datum = window.mapData[i];\r\n      var loc = new L.LatLng(datum.lat, datum.lon);\r\n      var marker = new L.Marker(loc);\r\n      marker.desc = datum.d;\r\n      map.addLayer(marker);\r\n      //oms.addMarker(marker);  // <-- here\r\n    } */\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","config","MapComponent","locations","onLocationUpdate","mapRef","map","setMap","online","setOnline","navigator","onLine","GisStationsStaticDistrict","setGisStationsStaticDistrict","dataStatus","setDataStatus","dataIcons","setDataIcons","dataSystem","setDataSystem","mapGisStationsStaticDistrictUrl","mapDataStatusUrl","mapDataIconUrl","mapDataSystemUrl","console","log","fetchData","response","fetch","jsonResponse","json","Points","error","checkInternet","responses","Promise","all","then","res","Statis","List","Systems","filter","system","Allow","offlineTileLayer","onlineTileLayer","TALAS","layerGroup","ECI","ULAF","GSMModem","CiscoRouter","WAGO","Siemens","OTDR","WDM","GMA","Sonstige","TALASICL","initialMap","serverURL","windowHeight","method","ok","catch","current","center","zoom","layers","zoomControl","contextmenu","contextmenuItems","text","callback","showAddStationPopup","icon","newLink","sameLink","lata","zoomIn","zoomOut","centerHere","tileLayer","attribution","addTo","window","addEventListener","removeEventListener","newLayer","minZoom","maxZoom","eachLayer","layer","TileLayer","removeLayer","Marker","forEach","location","latitude","longitude","parsePoint","position","marker","iconUrl","iconSize","iconAnchor","popupAnchor","draggable","id","idPoi","bindPopup","description","idPoiTyp","toFixed","on","e","newLat","target","getLatLng","lat","newLng","lng","markerId","options","updateLocationInDatabase","pointString","match","parseFloat","relatedTarget","Error","alert","test","open","focus","latlng","flyTo","fly","panTo","showCoordinates","showData","showTalas","addLayer","loadData","hideTalas","showGSM","hideGSM","popupContent","DomUtil","create","innerHTML","popup","setLatLng","setContent","openOn","DomEvent","handleSubmit","event","preventDefault","form","data","name","value","type","headers","body","JSON","stringify","result","reset","message","stationValue","x","y","div","ref","style","height","width","overflow"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./components/MapComponent.js\n");
/***/ }),
/***/ "./config/config.js":
/*!**************************!*\
!*** ./config/config.js ***!
\**************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ c: () => (/* binding */ c),\n/* harmony export */ fullSideMenu: () => (/* binding */ fullSideMenu),\n/* harmony export */ mapDataIconUrl: () => (/* binding */ mapDataIconUrl),\n/* harmony export */ mapDataMeasures: () => (/* binding */ mapDataMeasures),\n/* harmony export */ mapDataStatusUrl: () => (/* binding */ mapDataStatusUrl),\n/* harmony export */ mapDataSystemUrl: () => (/* binding */ mapDataSystemUrl),\n/* harmony export */ mapGisStationsStaticDistrictUrl: () => (/* binding */ mapGisStationsStaticDistrictUrl),\n/* harmony export */ mapIconsOfflineURL: () => (/* binding */ mapIconsOfflineURL),\n/* harmony export */ mapMeasuresOfflineURL: () => (/* binding */ mapMeasuresOfflineURL),\n/* harmony export */ mapStaticOfflineURL: () => (/* binding */ mapStaticOfflineURL),\n/* harmony export */ mapStatusOfflineURL: () => (/* binding */ mapStatusOfflineURL),\n/* harmony export */ mapSystemOfflineURL: () => (/* binding */ mapSystemOfflineURL),\n/* harmony export */ mapVersion: () => (/* binding */ mapVersion),\n/* harmony export */ offlineData: () => (/* binding */ offlineData),\n/* harmony export */ serverURL: () => (/* binding */ serverURL),\n/* harmony export */ standardSideMenu: () => (/* binding */ standardSideMenu),\n/* harmony export */ url: () => (/* binding */ url),\n/* harmony export */ url_string: () => (/* binding */ url_string),\n/* harmony export */ user: () => (/* binding */ user),\n/* harmony export */ windowHeight: () => (/* binding */ windowHeight)\n/* harmony export */ });\n// Definieren der grundlegenden Umgebungseinstellungen und Konfigurationen der Karte\nconst mapVersion = \"0.5.3\"; // Die Version der verwendeten Karte\nconst standardSideMenu = true; // Einstellung, ob ein standardmäßiges Seitenmenü verwendet wird\nconst fullSideMenu = false; // Einstellung, ob ein vollständiges Seitenmenü verwendet wird\nconst offlineData = false; // Schalter, um anzugeben, ob Daten offline verfügbar gemacht werden sollen\nconst serverURL = \"/api\"; // Die Basis-URL des Servers, von dem Daten bezogen werden\n// Initialisieren von Variablen, die später im Browserkontext gesetzt werden\nlet windowHeight, url_string, url, c, user;\nlet mapGisStationsStaticDistrictUrl, mapDataStatusUrl, mapDataMeasures, mapDataIconUrl, mapDataSystemUrl;\nlet mapStaticOfflineURL, mapStatusOfflineURL, mapSystemOfflineURL, mapIconsOfflineURL, mapMeasuresOfflineURL;\n// Prüfen, ob das Code im Browser ausgeführt wird\nif (false) {}\n// Export der definierten Variablen und URLs, damit sie in anderen Teilen der Anwendung verwendet werden können\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9jb25maWcvY29uZmlnLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsb0ZBQW9GO0FBQ3BGLE1BQU1BLGFBQWEsU0FBUyxvQ0FBb0M7QUFDaEUsTUFBTUMsbUJBQW1CLE1BQU0sZ0VBQWdFO0FBQy9GLE1BQU1DLGVBQWUsT0FBTyw4REFBOEQ7QUFDMUYsTUFBTUMsY0FBYyxPQUFPLDJFQUEyRTtBQUN0RyxNQUFNQyxZQUFZLFFBQVEsMERBQTBEO0FBRXBGLDRFQUE0RTtBQUM1RSxJQUFJQyxjQUFjQyxZQUFZQyxLQUFLQyxHQUFHQztBQUN0QyxJQUFJQyxpQ0FDRkMsa0JBQ0FDLGlCQUNBQyxnQkFDQUM7QUFDRixJQUFJQyxxQkFDRkMscUJBQ0FDLHFCQUNBQyxvQkFDQUM7QUFFRixpREFBaUQ7QUFDakQsSUFBSSxLQUE2QixFQUFFLEVBMEJsQztBQUVELCtHQUErRztBQXNCN0ciLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9jb25maWcvY29uZmlnLmpzP2FhMDQiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gRGVmaW5pZXJlbiBkZXIgZ3J1bmRsZWdlbmRlbiBVbWdlYnVuZ3NlaW5zdGVsbHVuZ2VuIHVuZCBLb25maWd1cmF0aW9uZW4gZGVyIEthcnRlXHJcbmNvbnN0IG1hcFZlcnNpb24gPSBcIjAuNS4zXCI7IC8vIERpZSBWZXJzaW9uIGRlciB2ZXJ3ZW5kZXRlbiBLYXJ0ZVxyXG5jb25zdCBzdGFuZGFyZFNpZGVNZW51ID0gdHJ1ZTsgLy8gRWluc3RlbGx1bmcsIG9iIGVpbiBzdGFuZGFyZG3DpMOfaWdlcyBTZWl0ZW5tZW7DvCB2ZXJ3ZW5kZXQgd2lyZFxyXG5jb25zdCBmdWxsU2lkZU1lbnUgPSBmYWxzZTsgLy8gRWluc3RlbGx1bmcsIG9iIGVpbiB2b2xsc3TDpG5kaWdlcyBTZWl0ZW5tZW7DvCB2ZXJ3ZW5kZXQgd2lyZFxyXG5jb25zdCBvZmZsaW5lRGF0YSA9IGZhbHNlOyAvLyBTY2hhbHRlciwgdW0gYW56dWdlYmVuLCBvYiBEYXRlbiBvZmZsaW5lIHZlcmbDvGdiYXIgZ2VtYWNodCB3ZXJkZW4gc29sbGVuXHJcbmNvbnN0IHNlcnZlclVSTCA9IFwiL2FwaVwiOyAvLyBEaWUgQmFzaXMtVVJMIGRlcyBTZXJ2ZXJzLCB2b24gZGVtIERhdGVuIGJlem9nZW4gd2VyZGVuXHJcblxyXG4vLyBJbml0aWFsaXNpZXJlbiB2b24gVmFyaWFibGVuLCBkaWUgc3DDpHRlciBpbSBCcm93c2Vya29udGV4dCBnZXNldHp0IHdlcmRlblxyXG5sZXQgd2luZG93SGVpZ2h0LCB1cmxfc3RyaW5nLCB1cmwsIGMsIHVzZXI7XHJcbmxldCBtYXBHaXNTdGF0aW9uc1N0YXRpY0Rpc3RyaWN0VXJsLFxyXG4gIG1hcERhdGFTdGF0dXNVcmwsXHJcbiAgbWFwRGF0YU1lYXN1cmVzLFxyXG4gIG1hcERhdGFJY29uVXJsLFxyXG4gIG1hcERhdGFTeXN0ZW1Vcmw7XHJcbmxldCBtYXBTdGF0aWNPZmZsaW5lVVJMLFxyXG4gIG1hcFN0YXR1c09mZmxpbmVVUkwsXHJcbiAgbWFwU3lzdGVtT2ZmbGluZVVSTCxcclxuICBtYXBJY29uc09mZmxpbmVVUkwsXHJcbiAgbWFwTWVhc3VyZXNPZmZsaW5lVVJMO1xyXG5cclxuLy8gUHLDvGZlbiwgb2IgZGFzIENvZGUgaW0gQnJvd3NlciBhdXNnZWbDvGhydCB3aXJkXHJcbmlmICh0eXBlb2Ygd2luZG93ICE9PSBcInVuZGVmaW5lZFwiKSB7XHJcbiAgLy8gRGllc2UgVmFyaWFibGVuIHdlcmRlbiBudXIgaW0gQnJvd3Nlci1Lb250ZXh0IGluaXRpYWxpc2llcnRcclxuICB3aW5kb3dIZWlnaHQgPSB3aW5kb3cuaW5uZXJIZWlnaHQ7IC8vIERpZSBIw7ZoZSBkZXMgQnJvd3NlcmZlbnN0ZXJzXHJcbiAgdXJsX3N0cmluZyA9IHdpbmRvdy5sb2NhdGlvbi5ocmVmOyAvLyBEaWUgdm9sbHN0w6RuZGlnZSBVUkwgYWxzIFN0cmluZ1xyXG4gIHVybCA9IG5ldyBVUkwodXJsX3N0cmluZyk7IC8vIERpZSBVUkwgYWxzIFVSTC1PYmpla3QsIHVtIFRlaWxlIGRlciBVUkwgZWluZmFjaGVyIHp1IGhhbmRoYWJlblxyXG4gIGMgPSB1cmwuc2VhcmNoUGFyYW1zLmdldChcIm1cIikgfHwgXCIxMFwiOyAvLyBFaW4gUGFyYW1ldGVyIGF1cyBkZXIgVVJMLCBTdGFuZGFyZHdlcnQgaXN0ICcxMCdcclxuICB1c2VyID0gdXJsLnNlYXJjaFBhcmFtcy5nZXQoXCJ1XCIpIHx8IFwiNDg1XCI7IC8vIEVpbiB3ZWl0ZXJlciBQYXJhbWV0ZXIgYXVzIGRlciBVUkwsIFN0YW5kYXJkd2VydCBpc3QgJzQ4NyBvZGVyIDQ4NCBvZGVyIDQ4NSdcclxuXHJcbiAgLy8gS29uc3RydWt0aW9uIHZvbiBVUkxzLCBkaWUgYXVmIHNwZXppZmlzY2hlIFJlc3NvdXJjZW4gYXVmIGRlbSBTZXJ2ZXIgemVpZ2VuXHJcbiAgbWFwR2lzU3RhdGlvbnNTdGF0aWNEaXN0cmljdFVybCA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dpc1N0YXRpb25zU3RhdGljRGlzdHJpY3Q/aWRNYXA9JHtjfSZpZFVzZXI9JHt1c2VyfWA7XHJcbiAgbWFwRGF0YVN0YXR1c1VybCA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dpc1N0YXRpb25zU3RhdHVzRGlzdHJpY3Q/aWRNYXA9JHtjfSZpZFVzZXI9JHt1c2VyfWA7XHJcbiAgbWFwRGF0YU1lYXN1cmVzID0gYCR7c2VydmVyVVJMfS90YWxhczUvQ2xpZW50RGF0YS9XZWJzZXJ2aWNlTWFwLmFzbXgvR2lzU3RhdGlvbnNNZWFzdXJlbWVudHM/aWRNYXA9JHtjfWA7XHJcbiAgbWFwRGF0YUljb25VcmwgPSBgJHtzZXJ2ZXJVUkx9L3RhbGFzNS9DbGllbnREYXRhL1dlYnNlcnZpY2VNYXAuYXNteC9HZXRJY29uc1N0YXRpY2A7XHJcbiAgbWFwRGF0YVN5c3RlbVVybCA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dpc1N5c3RlbVN0YXRpYz9pZE1hcD0ke2N9JmlkVXNlcj0ke3VzZXJ9YDtcclxuXHJcbiAgLyogICBtYXBHaXNTdGF0aW9uc1N0YXRpY0Rpc3RyaWN0VXJsID0gYCR7c2VydmVyVVJMfS90YWxhczUvQ2xpZW50RGF0YS9XZWJzZXJ2aWNlTWFwLmFzbXgvR2lzU3RhdGlvbnNTdGF0aWNEaXN0cmljdGA7XHJcbiAgbWFwRGF0YVN0YXR1c1VybCA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dpc1N0YXRpb25zU3RhdHVzRGlzdHJpY3RgO1xyXG4gIG1hcERhdGFNZWFzdXJlcyA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dpc1N0YXRpb25zTWVhc3VyZW1lbnRzYDtcclxuICBtYXBEYXRhSWNvblVybCA9IGAke3NlcnZlclVSTH0vdGFsYXM1L0NsaWVudERhdGEvV2Vic2VydmljZU1hcC5hc214L0dldEljb25zU3RhdGljYDtcclxuICBtYXBEYXRhU3lzdGVtVXJsID0gYCR7c2VydmVyVVJMfS90YWxhczUvQ2xpZW50RGF0YS9XZWJzZXJ2aWNlTWFwLmFzbXgvR2lzU3lzdGVtU3RhdGljYDsgKi9cclxuICAvLyBVUkxzIHp1IE9mZmxpbmUtRGF0ZW4sIGZhbGxzIGJlbsO2dGlndFxyXG4gIG1hcFN0YXRpY09mZmxpbmVVUkwgPSBgb2ZmbGluZVRlc3REYXRhL2lkTWFwJHtjfUdpc1N0YXRpb25lblN0YXRpYy5qc29uYDtcclxuICBtYXBTdGF0dXNPZmZsaW5lVVJMID0gYG9mZmxpbmVUZXN0RGF0YS9pZE1hcCR7Y31HaXNTdGF0aW9uZW5TdGF0dXMuanNvbmA7XHJcbiAgbWFwU3lzdGVtT2ZmbGluZVVSTCA9IGBvZmZsaW5lVGVzdERhdGEvaWRNYXAke2N9R2lzU3lzdGVtU3RhdGljLmpzb25gO1xyXG4gIG1hcEljb25zT2ZmbGluZVVSTCA9IFwib2ZmbGluZVRlc3REYXRhL2ljb25zLmpzb25cIjtcclxuICBtYXBNZWFzdXJlc09mZmxpbmVVUkwgPSBgb2ZmbGluZVRlc3REYXRhL2lkTWFwJHtjfUdpc1N5c3RlbU1lYXN1cmVzLmpzb25gO1xyXG59XHJcblxyXG4vLyBFeHBvcnQgZGVyIGRlZmluaWVydGVuIFZhcmlhYmxlbiB1bmQgVVJMcywgZGFtaXQgc2llIGluIGFuZGVyZW4gVGVpbGVuIGRlciBBbndlbmR1bmcgdmVyd2VuZGV0IHdlcmRlbiBrw7ZubmVuXHJcbmV4cG9ydCB7XHJcbiAgbWFwVmVyc2lvbixcclxuICBzdGFuZGFyZFNpZGVNZW51LFxyXG4gIGZ1bGxTaWRlTWVudSxcclxuICBvZmZsaW5lRGF0YSxcclxuICBzZXJ2ZXJVUkwsXHJcbiAgd2luZG93SGVpZ2h0LFxyXG4gIHVybF9zdHJpbmcsXHJcbiAgdXJsLFxyXG4gIGMsXHJcbiAgdXNlcixcclxuICBtYXBHaXNTdGF0aW9uc1N0YXRpY0Rpc3RyaWN0VXJsLFxyXG4gIG1hcERhdGFTdGF0dXNVcmwsXHJcbiAgbWFwRGF0YU1lYXN1cmVzLFxyXG4gIG1hcERhdGFJY29uVXJsLFxyXG4gIG1hcERhdGFTeXN0ZW1VcmwsXHJcbiAgbWFwU3RhdGljT2ZmbGluZVVSTCxcclxuICBtYXBTdGF0dXNPZmZsaW5lVVJMLFxyXG4gIG1hcFN5c3RlbU9mZmxpbmVVUkwsXHJcbiAgbWFwSWNvbnNPZmZsaW5lVVJMLFxyXG4gIG1hcE1lYXN1cmVzT2ZmbGluZVVSTCxcclxufTtcclxuIl0sIm5hbWVzIjpbIm1hcFZlcnNpb24iLCJzdGFuZGFyZFNpZGVNZW51IiwiZnVsbFNpZGVNZW51Iiwib2ZmbGluZURhdGEiLCJzZXJ2ZXJVUkwiLCJ3aW5kb3dIZWlnaHQiLCJ1cmxfc3RyaW5nIiwidXJsIiwiYyIsInVzZXIiLCJtYXBHaXNTdGF0aW9uc1N0YXRpY0Rpc3RyaWN0VXJsIiwibWFwRGF0YVN0YXR1c1VybCIsIm1hcERhdGFNZWFzdXJlcyIsIm1hcERhdGFJY29uVXJsIiwibWFwRGF0YVN5c3RlbVVybCIsIm1hcFN0YXRpY09mZmxpbmVVUkwiLCJtYXBTdGF0dXNPZmZsaW5lVVJMIiwibWFwU3lzdGVtT2ZmbGluZVVSTCIsIm1hcEljb25zT2ZmbGluZVVSTCIsIm1hcE1lYXN1cmVzT2ZmbGluZVVSTCIsIndpbmRvdyIsImlubmVySGVpZ2h0IiwibG9jYXRpb24iLCJocmVmIiwiVVJMIiwic2VhcmNoUGFyYW1zIiwiZ2V0Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./config/config.js\n");
/***/ })
};
;