@kando-env/kando-ui 1.2.354-alpha.3 → 1.2.354-alpha.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/Widgets/Map/Map.js
CHANGED
|
@@ -176,7 +176,11 @@ const Map = _ref => {
|
|
|
176
176
|
if (!mapRef.current) {
|
|
177
177
|
(0, _MapUtils.initializeMap)(mapZoomLevel, mapBoxStyle, _theme.leafletMap.satellite, mapRef, dispatch, _MapUtils.isValidArea, areaToCenterBy, setMapZoomLevel, forWWTPDashboard);
|
|
178
178
|
} else {
|
|
179
|
-
(
|
|
179
|
+
setMapZoomLevel(mapRef.current.getZoom());
|
|
180
|
+
if (!areaToCenterBy) {
|
|
181
|
+
areaToCenterBy = areas.map(area => area.shape_data);
|
|
182
|
+
}
|
|
183
|
+
(0, _MapUtils.areaFocusLogic)(mapRef, _MapUtils.isValidArea, areaToCenterBy);
|
|
180
184
|
}
|
|
181
185
|
}, [mapRef.current, areaToCenterBy]);
|
|
182
186
|
(0, _react.useEffect)(() => {
|
|
@@ -213,4 +217,4 @@ const Map = _ref => {
|
|
|
213
217
|
}), (0, _MapUtils.shoudLoadDependentMapObjects)(edges, areas, global_data, mapRef, points) && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, memoizedEvent, memoizedZoomControl, children))));
|
|
214
218
|
};
|
|
215
219
|
exports.Map = Map;
|
|
216
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_i18n","_ListContext","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Map","_ref","areas","edges","points","global_data","areaToCenterBy","focusedEvent","hoveredEvent","hideEdges","mapBoxStyle","leafletMap","mapDefault","children","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","style","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","mapZoomLevel","setMapZoomLevel","useState","selectedItem","useSelectedItem","eventsData","useSelector","state","events_data","hoveredEventPresent","useMemo","undefined","focusedEventPresent","factoriesClusterGroup","window","customLeaflet","markerClusterGroup","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","wwtpsLayerGroup","layerGroup","collectorsLayerGroup","areasLayerGroup","FeatureGroup","memoizedPoints","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","zoomRulesForEventsView","payload","Fragment","allowUnmonitoredDescendants","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","clearLayers","removeLayer","initializeMap","satellite","isValidArea","remove","waterAuthorityId","areaFocusLogic","_mapRef$current2","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\nimport 'leaflet.markercluster';\nimport 'leaflet.pattern';\nimport React, {\n  CSSProperties,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IEvent } from 'src/store/events/models/IEvent';\n// import { storeMap } from 'src/store/global/actions';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport ErrorBoundary from 'src/utilities/ErrorBoundary';\nimport { AreaPolygons } from './areas/AreaPolygons';\nimport Edges from './edges/Edges';\nimport './Map.scss';\nimport './points/PointIcon.scss';\nimport { PointMarkers } from './points/PointMarkers';\nimport { appReducer } from '../../store/rootReducer';\nimport { Event } from './events/Event';\nimport {\n  areaFocusLogic,\n  initializeMap,\n  isValidArea,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport i18n from '../../utilities/i18n';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  const eventsData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.events_data,\n  );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  const [factoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup({\n      spiderfyOnMaxZoom: false,\n      showCoverageOnHover: false,\n      zoomToBoundsOnClick: true,\n      animate: true,\n      disableClusteringAtZoom: 15,\n      removeOutsideVisibleBounds: false,\n      chunkedLoading: true,\n      iconCreateFunction: function (cluster) {\n        return new L.DivIcon({\n          html: `<div><span>${\n            cluster._childCount\n          }</span></div><div class='marker-cluster-name'>${i18n.t(\n            'industries',\n          )}</div>`,\n          className: 'marker-cluster',\n          iconSize: new L.Point(40, 40),\n        });\n      },\n    }),\n  );\n\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  //const [factoriesLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n\n  const memoizedPoints = useMemo(() => {\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={points}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={factoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  // const activateZoomControlForIcons = useMemo(() => {\n  //   mapRef.current !== null && iconZoomControl(mapRef.current);\n  // }, [mapRef.current, points, focusedEventPresent]);\n\n  const zoomRulesForEventsView = () => {\n    const payload = (\n      <>\n        <Edges\n          edges={edges!}\n          map={mapRef.current}\n          L={L}\n          points={points!}\n          hideEdges={hideEdges}\n          allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n        />\n        {memoizedPoints}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = <>{memoizedPoints}</>;\n    switch (zoomLevels[mapZoomLevel]) {\n      case 'Small':\n      case 'Medium':\n        payload = zoomRulesForEventsView();\n        break;\n      // case 'MLarge':\n      // case 'Large':\n      // case 'XLarge':\n      // default:\n      //   payload = <>{memoizedPoints}</>;\n      //   break;\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = useMemo(() => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\n\n    return payload;\n  }, [\n    mapZoomLevel,\n    eventsData.isFetching,\n    focusedEvent,\n    hoveredEvent,\n    points,\n    mapRef.current,\n  ]);\n\n  const memoizedEvent = useMemo(() => {\n    if (focusedEventPresent) {\n      focusedEvent!.focused = focusedEventPresent;\n      focusedEvent!.hovered = !focusedEventPresent;\n    }\n\n    if (hoveredEventPresent) {\n      hoveredEvent!.hovered = hoveredEventPresent;\n      hoveredEvent!.focused = !hoveredEventPresent;\n    }\n\n    if (!hoveredEventPresent && !focusedEventPresent) return <></>;\n    return (\n      <Event\n        event={focusedEvent! || hoveredEvent!}\n        map={map}\n        edges={edges!}\n        points={points!}\n        includeNetwork={!hoveredEventPresent}\n      />\n    );\n  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  useEffect(() => {\n    return function cleanup() {\n      collectorsLayerGroup.clearLayers();\n      mapRef.current?.removeLayer(collectorsLayerGroup);\n    };\n  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  useEffect(() => {\n    initializeMap(\n      mapZoomLevel,\n      mapBoxStyle,\n      leafletMap.satellite,\n      mapRef,\n      dispatch,\n      isValidArea,\n      areaToCenterBy,\n      setMapZoomLevel,\n      forWWTPDashboard,\n    );\n\n    return function cleanup() {\n      // factoriesClusterGroup.clearLayers();\n      // wwtpsLayerGroup.clearLayers();\n      // collectorsLayerGroup.clearLayers();\n      // areasLayerGroup.clearLayers();\n      // mapRef.current?.removeLayer(factoriesClusterGroup);\n      // mapRef.current?.removeLayer(wwtpsLayerGroup);\n      // mapRef.current?.removeLayer(collectorsLayerGroup);\n      // mapRef.current?.removeLayer(areasLayerGroup);\n      // @ts-ignore\n      mapRef.current.remove();\n      // dispatch(storeMap(undefined));\n    };\n  }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      initializeMap(\n        mapZoomLevel,\n        mapBoxStyle,\n        leafletMap.satellite,\n        mapRef,\n        dispatch,\n        isValidArea,\n        areaToCenterBy,\n        setMapZoomLevel,\n        forWWTPDashboard,\n      );\n    } else {\n      areaFocusLogic(\n        mapRef,\n        isValidArea,\n        areaToCenterBy ? areaToCenterBy : areas[0],\n      );\n    }\n  }, [mapRef.current, areaToCenterBy]);\n\n  useEffect(() => {\n    let clicked = false;\n\n    mapRef.current?.eachLayer((layer) => {\n      if (clicked) return;\n\n      if (\n        layer?.kando_object_id === selectedItem &&\n        layer.isPopupOpen() === false\n      ) {\n        if (layer instanceof L.Marker) {\n          layer.fire('click');\n        } else if (layer instanceof L.Polygon) {\n          layer.fire('click-event');\n        }\n        clicked = true;\n      }\n    });\n  }, [selectedItem]);\n\n  return (\n    <div className=\"kd-map-container\" style={style}>\n      <div\n        className={` map-container ${\n          global_data.sidenavExpanded ? '' : 'map-container--sidenav-collapsed'\n        }`}\n      >\n        <ErrorBoundary>\n          <div id=\"map\"></div>\n          {shouldLoadMapObjects(global_data, mapRef, edges, points) && (\n            <AreaPolygons\n              areas={areas}\n              map={mapRef.current}\n              L={L}\n              areaToCenterBy={areaToCenterBy}\n              mapZoom={mapZoomLevel}\n              rerender={zoomLevels[mapZoomLevel]}\n              global_data={global_data}\n              featureGroup={areasLayerGroup}\n            />\n          )}\n          {shoudLoadDependentMapObjects(\n            edges,\n            areas,\n            global_data,\n            mapRef,\n            points,\n          ) && (\n            <>\n              {memoizedEvent}\n              {memoizedZoomControl}\n              {children}\n            </>\n          )}\n        </ErrorBoundary>\n      </div>\n    </div>\n  );\n};\n"],"mappings":"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"}
|
|
220
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["L","_interopRequireWildcard","require","_react","_reactRedux","_ErrorBoundary","_interopRequireDefault","_AreaPolygons","_Edges","_PointMarkers","_Event","_MapUtils","_theme","_i18n","_ListContext","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Map","_ref","areas","edges","points","global_data","areaToCenterBy","focusedEvent","hoveredEvent","hideEdges","mapBoxStyle","leafletMap","mapDefault","children","includeUnmonitoredPoints","includeUnmonitoredDescendantsForEdges","forEventsView","style","forWWTPDashboard","map","mapRef","useRef","dispatch","useDispatch","mapZoomLevel","setMapZoomLevel","useState","selectedItem","useSelectedItem","eventsData","useSelector","state","events_data","hoveredEventPresent","useMemo","undefined","focusedEventPresent","factoriesClusterGroup","window","customLeaflet","markerClusterGroup","spiderfyOnMaxZoom","showCoverageOnHover","zoomToBoundsOnClick","animate","disableClusteringAtZoom","removeOutsideVisibleBounds","chunkedLoading","iconCreateFunction","cluster","DivIcon","html","concat","_childCount","i18n","t","className","iconSize","Point","wwtpsLayerGroup","layerGroup","collectorsLayerGroup","areasLayerGroup","FeatureGroup","memoizedPoints","current","createElement","PointMarkers","rerender","zoomLevels","factoriesGroup","wwtpsGroup","collectorsGroup","zoomRulesForEventsView","payload","Fragment","allowUnmonitoredDescendants","zoomRulesForDashaboardMaps","memoizedZoomControl","isFetching","memoizedEvent","focused","hovered","Event","event","includeNetwork","eventFilterParam","useEffect","cleanup","_mapRef$current","clearLayers","removeLayer","initializeMap","satellite","isValidArea","remove","waterAuthorityId","getZoom","area","shape_data","areaFocusLogic","_mapRef$current2","clicked","eachLayer","layer","kando_object_id","isPopupOpen","Marker","fire","Polygon","sidenavExpanded","id","shouldLoadMapObjects","AreaPolygons","mapZoom","featureGroup","shoudLoadDependentMapObjects","exports"],"sources":["../../../src/Widgets/Map/Map.tsx"],"sourcesContent":["// @ts-ignore\nimport * as L from 'leaflet';\nimport 'leaflet.markercluster';\nimport 'leaflet.pattern';\nimport React, {\n  CSSProperties,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { IArea } from 'src/store/areas/models/IArea';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IEvent } from 'src/store/events/models/IEvent';\n// import { storeMap } from 'src/store/global/actions';\nimport { IGlobalState } from 'src/store/global/models/IGlobalState';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport ErrorBoundary from 'src/utilities/ErrorBoundary';\nimport { AreaPolygons } from './areas/AreaPolygons';\nimport Edges from './edges/Edges';\nimport './Map.scss';\nimport './points/PointIcon.scss';\nimport { PointMarkers } from './points/PointMarkers';\nimport { appReducer } from '../../store/rootReducer';\nimport { Event } from './events/Event';\nimport {\n  areaFocusLogic,\n  initializeMap,\n  isValidArea,\n  shoudLoadDependentMapObjects,\n  shouldLoadMapObjects,\n  zoomLevels,\n} from './MapUtils';\nimport { leafletMap } from '../../styles/theme/theme';\nimport i18n from '../../utilities/i18n';\nimport { useSelectedItem } from 'src/pages/DashboardMap/ListContext';\nrequire('leaflet.markercluster');\n\ninterface MapProps {\n  areas: IArea[];\n  edges?: IEdge[];\n  points?: IPoint[];\n  global_data: IGlobalState;\n  areaToCenterBy?: any;\n  focusedEvent?: IEvent | null;\n  hoveredEvent?: IEvent | null;\n  hideEdges?: boolean;\n  mapBoxStyle?: string;\n  children?: any;\n  style?: CSSProperties;\n  includeUnmonitoredPoints?: boolean;\n  includeUnmonitoredDescendantsForEdges?: boolean;\n  forEventsView: boolean;\n  forWWTPDashboard?: boolean;\n}\n\nexport const Map: React.FC<MapProps> = ({\n  areas,\n  edges,\n  points,\n  global_data,\n  areaToCenterBy,\n  focusedEvent,\n  hoveredEvent,\n  hideEdges = false,\n  mapBoxStyle = leafletMap.mapDefault,\n  children,\n  includeUnmonitoredPoints = true,\n  includeUnmonitoredDescendantsForEdges = false,\n  forEventsView = false,\n  style = {},\n  forWWTPDashboard = false,\n}) => {\n  const { map } = global_data;\n  const mapRef = useRef<L.Map | null>(null);\n  const dispatch = useDispatch();\n  const [mapZoomLevel, setMapZoomLevel] = useState(2);\n  const { selectedItem } = useSelectedItem();\n  const eventsData = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.events_data,\n  );\n  const hoveredEventPresent = useMemo(() => {\n    return hoveredEvent !== null && hoveredEvent !== undefined;\n  }, [hoveredEvent]);\n\n  const focusedEventPresent = useMemo(() => {\n    return focusedEvent !== null && focusedEvent !== undefined;\n  }, [focusedEvent]);\n\n  const [factoriesClusterGroup] = useState(\n    window.customLeaflet.markerClusterGroup({\n      spiderfyOnMaxZoom: false,\n      showCoverageOnHover: false,\n      zoomToBoundsOnClick: true,\n      animate: true,\n      disableClusteringAtZoom: 15,\n      removeOutsideVisibleBounds: false,\n      chunkedLoading: true,\n      iconCreateFunction: function (cluster) {\n        return new L.DivIcon({\n          html: `<div><span>${\n            cluster._childCount\n          }</span></div><div class='marker-cluster-name'>${i18n.t(\n            'industries',\n          )}</div>`,\n          className: 'marker-cluster',\n          iconSize: new L.Point(40, 40),\n        });\n      },\n    }),\n  );\n\n  const [wwtpsLayerGroup] = useState(L.layerGroup());\n  const [collectorsLayerGroup] = useState(L.layerGroup());\n  //const [factoriesLayerGroup] = useState(L.layerGroup());\n  const [areasLayerGroup] = useState(new L.FeatureGroup());\n\n  const memoizedPoints = useMemo(() => {\n    return (\n      mapRef.current !== null &&\n      points && (\n        <PointMarkers\n          map={mapRef.current}\n          points={points}\n          includeUnmonitoredPoints={includeUnmonitoredPoints}\n          rerender={zoomLevels[mapZoomLevel]}\n          factoriesGroup={factoriesClusterGroup}\n          wwtpsGroup={wwtpsLayerGroup}\n          collectorsGroup={collectorsLayerGroup}\n          forEventsView={false}\n        />\n      )\n    );\n  }, [mapRef.current, points, focusedEventPresent, mapZoomLevel]);\n\n  // const activateZoomControlForIcons = useMemo(() => {\n  //   mapRef.current !== null && iconZoomControl(mapRef.current);\n  // }, [mapRef.current, points, focusedEventPresent]);\n\n  const zoomRulesForEventsView = () => {\n    const payload = (\n      <>\n        <Edges\n          edges={edges!}\n          map={mapRef.current}\n          L={L}\n          points={points!}\n          hideEdges={hideEdges}\n          allowUnmonitoredDescendants={includeUnmonitoredDescendantsForEdges}\n        />\n        {memoizedPoints}\n      </>\n    );\n\n    return payload;\n  };\n\n  const zoomRulesForDashaboardMaps = () => {\n    let payload = <>{memoizedPoints}</>;\n    switch (zoomLevels[mapZoomLevel]) {\n      case 'Small':\n      case 'Medium':\n        payload = zoomRulesForEventsView();\n        break;\n      // case 'MLarge':\n      // case 'Large':\n      // case 'XLarge':\n      // default:\n      //   payload = <>{memoizedPoints}</>;\n      //   break;\n    }\n\n    return payload;\n  };\n\n  const memoizedZoomControl = useMemo(() => {\n    const payload = forEventsView\n      ? zoomRulesForEventsView()\n      : zoomRulesForDashaboardMaps();\n\n    return payload;\n  }, [\n    mapZoomLevel,\n    eventsData.isFetching,\n    focusedEvent,\n    hoveredEvent,\n    points,\n    mapRef.current,\n  ]);\n\n  const memoizedEvent = useMemo(() => {\n    if (focusedEventPresent) {\n      focusedEvent!.focused = focusedEventPresent;\n      focusedEvent!.hovered = !focusedEventPresent;\n    }\n\n    if (hoveredEventPresent) {\n      hoveredEvent!.hovered = hoveredEventPresent;\n      hoveredEvent!.focused = !hoveredEventPresent;\n    }\n\n    if (!hoveredEventPresent && !focusedEventPresent) return <></>;\n    return (\n      <Event\n        event={focusedEvent! || hoveredEvent!}\n        map={map}\n        edges={edges!}\n        points={points!}\n        includeNetwork={!hoveredEventPresent}\n      />\n    );\n  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  useEffect(() => {\n    return function cleanup() {\n      collectorsLayerGroup.clearLayers();\n      mapRef.current?.removeLayer(collectorsLayerGroup);\n    };\n  }, [focusedEvent, hoveredEvent, global_data.eventFilterParam]);\n\n  useEffect(() => {\n    initializeMap(\n      mapZoomLevel,\n      mapBoxStyle,\n      leafletMap.satellite,\n      mapRef,\n      dispatch,\n      isValidArea,\n      areaToCenterBy,\n      setMapZoomLevel,\n      forWWTPDashboard,\n    );\n\n    return function cleanup() {\n      // factoriesClusterGroup.clearLayers();\n      // wwtpsLayerGroup.clearLayers();\n      // collectorsLayerGroup.clearLayers();\n      // areasLayerGroup.clearLayers();\n      // mapRef.current?.removeLayer(factoriesClusterGroup);\n      // mapRef.current?.removeLayer(wwtpsLayerGroup);\n      // mapRef.current?.removeLayer(collectorsLayerGroup);\n      // mapRef.current?.removeLayer(areasLayerGroup);\n      // @ts-ignore\n      mapRef.current.remove();\n      // dispatch(storeMap(undefined));\n    };\n  }, [global_data.waterAuthorityId]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      initializeMap(\n        mapZoomLevel,\n        mapBoxStyle,\n        leafletMap.satellite,\n        mapRef,\n        dispatch,\n        isValidArea,\n        areaToCenterBy,\n        setMapZoomLevel,\n        forWWTPDashboard,\n      );\n    } else {\n      setMapZoomLevel(mapRef.current.getZoom());\n      if (!areaToCenterBy) {\n        areaToCenterBy = areas.map((area) => area.shape_data);\n      }\n\n      areaFocusLogic(mapRef, isValidArea, areaToCenterBy);\n    }\n  }, [mapRef.current, areaToCenterBy]);\n\n  useEffect(() => {\n    let clicked = false;\n\n    mapRef.current?.eachLayer((layer) => {\n      if (clicked) return;\n\n      if (\n        layer?.kando_object_id === selectedItem &&\n        layer.isPopupOpen() === false\n      ) {\n        if (layer instanceof L.Marker) {\n          layer.fire('click');\n        } else if (layer instanceof L.Polygon) {\n          layer.fire('click-event');\n        }\n        clicked = true;\n      }\n    });\n  }, [selectedItem]);\n\n  return (\n    <div className=\"kd-map-container\" style={style}>\n      <div\n        className={` map-container ${\n          global_data.sidenavExpanded ? '' : 'map-container--sidenav-collapsed'\n        }`}\n      >\n        <ErrorBoundary>\n          <div id=\"map\"></div>\n          {shouldLoadMapObjects(global_data, mapRef, edges, points) && (\n            <AreaPolygons\n              areas={areas}\n              map={mapRef.current}\n              L={L}\n              areaToCenterBy={areaToCenterBy}\n              mapZoom={mapZoomLevel}\n              rerender={zoomLevels[mapZoomLevel]}\n              global_data={global_data}\n              featureGroup={areasLayerGroup}\n            />\n          )}\n          {shoudLoadDependentMapObjects(\n            edges,\n            areas,\n            global_data,\n            mapRef,\n            points,\n          ) && (\n            <>\n              {memoizedEvent}\n              {memoizedZoomControl}\n              {children}\n            </>\n          )}\n        </ErrorBoundary>\n      </div>\n    </div>\n  );\n};\n"],"mappings":"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"}
|
|
@@ -19,6 +19,7 @@ const getAreaId = area => {
|
|
|
19
19
|
return name;
|
|
20
20
|
};
|
|
21
21
|
const genericPolygon = (area, mapZoom) => {
|
|
22
|
+
var _area$sub_areas;
|
|
22
23
|
let areaPolygon;
|
|
23
24
|
let latlngs = area.shape_data.map(location => {
|
|
24
25
|
return [location['lat'], location['lng']];
|
|
@@ -29,7 +30,7 @@ const genericPolygon = (area, mapZoom) => {
|
|
|
29
30
|
color,
|
|
30
31
|
fillOpacity: area.showColorOnlyInBorders ? 0.3 : 0.4,
|
|
31
32
|
weight: area.showColorOnlyInBorders ? 2 : 0,
|
|
32
|
-
fill: false
|
|
33
|
+
fill: (area === null || area === void 0 ? void 0 : (_area$sub_areas = area.sub_areas) === null || _area$sub_areas === void 0 ? void 0 : _area$sub_areas.length) > 0 ? false : true
|
|
33
34
|
});
|
|
34
35
|
return areaPolygon;
|
|
35
36
|
};
|
|
@@ -50,8 +51,7 @@ exports.calculatePolygonArea = calculatePolygonArea;
|
|
|
50
51
|
const polygonTitle = (area, mapZoom) => {
|
|
51
52
|
return "<div class=\"area-tooltip\" style=\"color:".concat(_theme.theme.colorScheme.primary.ps1, ";font-weight:700;background-color:transparent;font-size: ").concat(mapZoom * 1.5, "px;-webkit-text-stroke: 0.8px #ffffff;\"> ").concat(getAreaName(area), " \n </div>");
|
|
52
53
|
};
|
|
53
|
-
const bindTooltip = (layer, area) => {
|
|
54
|
-
const mapZoom = layer._map !== undefined ? layer._map.getZoom() : 0;
|
|
54
|
+
const bindTooltip = (layer, area, mapZoom) => {
|
|
55
55
|
const title = polygonTitle(area, mapZoom);
|
|
56
56
|
layer.bindTooltip(title, {
|
|
57
57
|
className: 'area-tooltip',
|
|
@@ -158,7 +158,7 @@ const createPolygon = (area, mapZoom, featureGroup, map, popupCreator) => {
|
|
|
158
158
|
}
|
|
159
159
|
polygon.addTo(featureGroup);
|
|
160
160
|
popupCreator && popupCreator(polygon, area);
|
|
161
|
-
bindTooltip(polygon, area);
|
|
161
|
+
bindTooltip(polygon, area, mapZoom);
|
|
162
162
|
zoomControlForArea(polygon, area, map, featureGroup);
|
|
163
163
|
return polygon;
|
|
164
164
|
}
|
|
@@ -172,4 +172,4 @@ const getPattern = area => {
|
|
|
172
172
|
const color = (0, _scoreToData.scoreToColor)(area.area_score);
|
|
173
173
|
return (0, _Patterns.assesmentPattern)(color);
|
|
174
174
|
};
|
|
175
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_scoreToData","_theme","_Patterns","getAreaName","area","name","area_name","getAreaId","area_id","id","genericPolygon","mapZoom","areaPolygon","latlngs","shape_data","map","location","length","color","scoreToColor","area_score","L","polygon","fillOpacity","showColorOnlyInBorders","weight","fill","exports","calculatePolygonArea","coordinates","numPoints","i","x1","y1","x2","y2","Math","abs","polygonTitle","concat","theme","colorScheme","primary","ps1","bindTooltip","layer","_map","undefined","getZoom","title","className","permanent","direction","handleToltipBasedOnZoomLevel","tooltip","getTooltip","setContent","openTooltip","closeTooltip","drillDownBasedOnZoomLevel","percentage","zoomPercentageToDrillDown","isPartialPolygonVisible","featureGroup","drillDownCondition","sub_areas","hidePolygon","bringToBack","setStyle","stroke","showPolygon","bringToFront","opacity","handleSubAreas","show","forEach","subAreaId","eachLayer","zoomControlForArea","on","getMapBounds","getBounds","polygonBounds","intersects","mapBoundsPolygon","getSouthWest","getNorthWest","getNorthEast","getSouthEast","mapBounds","toGeoJSON","geometry","areaSurface","customAttributesForAreaPolygon","calculated_surface","createPolygon","popupCreator","pattern","getPattern","addTo","fillPattern","is_assessment","assesmentPattern"],"sources":["../../../../src/Widgets/Map/areas/AreaUtils.ts"],"sourcesContent":["import L, { FeatureGroup, Polygon } from 'leaflet';\nimport 'leaflet.pattern';\nimport { scoreToColor } from '../../../utilities/scoreToData';\nimport { theme } from '../../../styles/theme/theme';\nimport { assesmentPattern } from './Patterns';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nconst getAreaName = (area) => {\n  let name = area.area_name || area.name;\n\n  return name;\n};\n\nconst getAreaId = (area) => {\n  let name = area.area_id || area.id;\n\n  return name;\n};\n\nexport const genericPolygon = (area, mapZoom) => {\n  let areaPolygon: Polygon;\n  let latlngs = area.shape_data.map((location: any) => {\n    return [location['lat'], location['lng']];\n  });\n\n  if (latlngs.length < 1) return;\n\n  let color = area.color ? area.color : scoreToColor(area.area_score);\n\n  areaPolygon = L.polygon(latlngs, {\n    color,\n    fillOpacity: area.showColorOnlyInBorders ? 0.3 : 0.4,\n    weight: area.showColorOnlyInBorders ? 2 : 0,\n    fill: false,\n  });\n\n  return areaPolygon;\n};\n\nexport const calculatePolygonArea = (coordinates) => {\n  let area = 0;\n  let numPoints = coordinates.length;\n\n  for (let i = 0; i < numPoints; i++) {\n    let x1 = coordinates[i][0];\n    let y1 = coordinates[i][1];\n    let x2 = coordinates[(i + 1) % numPoints][0];\n    let y2 = coordinates[(i + 1) % numPoints][1];\n\n    area += x1 * y2 - x2 * y1;\n  }\n\n  return Math.abs(area / 2);\n};\n\nconst polygonTitle = (area, mapZoom) => {\n  return `<div class=\"area-tooltip\" style=\"color:${\n    theme.colorScheme.primary.ps1\n  };font-weight:700;background-color:transparent;font-size: ${\n    mapZoom * 1.5\n  }px;-webkit-text-stroke: 0.8px #ffffff;\"> ${getAreaName(area)} \n        </div>`;\n};\n\nconst bindTooltip = (layer, area) => {\n  const mapZoom = layer._map !== undefined ? layer._map.getZoom() : 0;\n  const title = polygonTitle(area, mapZoom);\n  layer.bindTooltip(title, {\n    className: 'area-tooltip',\n    permanent: true,\n    direction: 'center',\n  });\n  handleToltipBasedOnZoomLevel(layer, mapZoom);\n};\n\n// The tooltip is showing the area name\nexport const handleToltipBasedOnZoomLevel = (polygon, mapZoom) => {\n  if (mapZoom > 11) {\n    const tooltip = polygon.getTooltip();\n    tooltip.setContent(polygonTitle(polygon, mapZoom));\n    polygon.openTooltip();\n  } else {\n    polygon.closeTooltip();\n  }\n};\n\nconst drillDownBasedOnZoomLevel = (\n  areaPolygon,\n  area,\n  percentage,\n  zoomPercentageToDrillDown,\n  isPartialPolygonVisible,\n  map,\n  featureGroup,\n) => {\n  const drillDownCondition = () => {\n    return (\n      percentage >= zoomPercentageToDrillDown &&\n      isPartialPolygonVisible &&\n      area.sub_areas.length !== 0 &&\n      areaPolygon._map !== null\n    );\n  };\n\n  const hidePolygon = (polygon: Polygon) => {\n    polygon.bringToBack();\n    polygon.closeTooltip();\n    polygon['hidden'] = true;\n    polygon.setStyle({\n      stroke: false,\n      fill: false,\n    });\n  };\n\n  const showPolygon = (polygon: Polygon, fill: boolean) => {\n    polygon.bringToFront();\n    polygon['hidden'] = false;\n    polygon.setStyle({\n      //stroke: fill ? false : true,\n      stroke: true,\n      opacity: 0.4,\n      weight: 2,\n      fill: fill,\n      fillOpacity: 0.4,\n    });\n  };\n\n  const handleSubAreas = (show: boolean) => {\n    if (areaPolygon['sub_areas'] !== undefined) {\n      areaPolygon['sub_areas'].forEach((subAreaId) => {\n        featureGroup.eachLayer((layer) => {\n          if (layer['kando_object_id'] === subAreaId) {\n            show ? showPolygon(layer, true) : hidePolygon(layer);\n          }\n        });\n      });\n    }\n  };\n\n  // Show the area with border only\n  // Or background color\n  if (drillDownCondition()) {\n    showPolygon(areaPolygon, false);\n    areaPolygon.closeTooltip();\n    handleSubAreas(true);\n  } else {\n    handleSubAreas(false);\n\n    if (!areaPolygon['hidden']) {\n      showPolygon(areaPolygon, true);\n      handleToltipBasedOnZoomLevel(areaPolygon, map.getZoom());\n    }\n  }\n};\n\nexport const zoomControlForArea = (areaPolygon, area, map, featureGroup) => {\n  map.on('zoomend', function () {\n    let getMapBounds = map.getBounds();\n    let polygonBounds = areaPolygon.getBounds();\n    let isPartialPolygonVisible = getMapBounds.intersects(polygonBounds);\n    let mapBoundsPolygon = L.polygon([\n      getMapBounds.getSouthWest(),\n      getMapBounds.getNorthWest(),\n      getMapBounds.getNorthEast(),\n      getMapBounds.getSouthEast(),\n    ]);\n\n    let mapBounds = calculatePolygonArea(\n      mapBoundsPolygon.toGeoJSON().geometry.coordinates[0],\n    );\n\n    let areaSurface = areaPolygon['calculated_surface'];\n    const zoomPercentageToDrillDown = 15.0;\n    const percentage = (areaSurface / mapBounds) * 100;\n\n    drillDownBasedOnZoomLevel(\n      areaPolygon,\n      area,\n      percentage,\n      zoomPercentageToDrillDown,\n      isPartialPolygonVisible,\n      map,\n      featureGroup,\n    );\n  });\n};\n\nconst customAttributesForAreaPolygon = (areaPolygon, area) => {\n  areaPolygon['kando_object_id'] = getAreaId(area);\n  areaPolygon['kando_object'] = 'Area';\n  areaPolygon['area_name'] = getAreaName(area);\n  areaPolygon['calculated_surface'] = area.calculated_surface;\n};\n\nexport const createPolygon = (\n  area,\n  mapZoom,\n  featureGroup: FeatureGroup,\n  map,\n  popupCreator?: (polygon: Polygon, area: IArea) => void,\n) => {\n  let polygon: Polygon;\n  if (\n    area.shape_data !== null &&\n    area.shape_data !== undefined &&\n    area.shape_data.length > 0\n  ) {\n    polygon = genericPolygon(area, mapZoom);\n\n    customAttributesForAreaPolygon(polygon, area);\n    const pattern = getPattern(area);\n    if (pattern) {\n      pattern?.addTo(map);\n      polygon.setStyle({\n        fillPattern: pattern,\n        color: scoreToColor(area.area_score),\n      });\n    }\n    polygon.addTo(featureGroup);\n    popupCreator && popupCreator(polygon, area);\n    bindTooltip(polygon, area);\n    zoomControlForArea(polygon, area, map, featureGroup);\n    return polygon;\n  }\n  return null;\n};\n\nconst getPattern = (area) => {\n  if (area.is_assessment === false) {\n    return null;\n  }\n  const color = scoreToColor(area.area_score);\n  return assesmentPattern(color);\n};\n"],"mappings":"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"}
|
|
175
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_scoreToData","_theme","_Patterns","getAreaName","area","name","area_name","getAreaId","area_id","id","genericPolygon","mapZoom","_area$sub_areas","areaPolygon","latlngs","shape_data","map","location","length","color","scoreToColor","area_score","L","polygon","fillOpacity","showColorOnlyInBorders","weight","fill","sub_areas","exports","calculatePolygonArea","coordinates","numPoints","i","x1","y1","x2","y2","Math","abs","polygonTitle","concat","theme","colorScheme","primary","ps1","bindTooltip","layer","title","className","permanent","direction","handleToltipBasedOnZoomLevel","tooltip","getTooltip","setContent","openTooltip","closeTooltip","drillDownBasedOnZoomLevel","percentage","zoomPercentageToDrillDown","isPartialPolygonVisible","featureGroup","drillDownCondition","_map","hidePolygon","bringToBack","setStyle","stroke","showPolygon","bringToFront","opacity","handleSubAreas","show","undefined","forEach","subAreaId","eachLayer","getZoom","zoomControlForArea","on","getMapBounds","getBounds","polygonBounds","intersects","mapBoundsPolygon","getSouthWest","getNorthWest","getNorthEast","getSouthEast","mapBounds","toGeoJSON","geometry","areaSurface","customAttributesForAreaPolygon","calculated_surface","createPolygon","popupCreator","pattern","getPattern","addTo","fillPattern","is_assessment","assesmentPattern"],"sources":["../../../../src/Widgets/Map/areas/AreaUtils.ts"],"sourcesContent":["import L, { FeatureGroup, Polygon } from 'leaflet';\nimport 'leaflet.pattern';\nimport { scoreToColor } from '../../../utilities/scoreToData';\nimport { theme } from '../../../styles/theme/theme';\nimport { assesmentPattern } from './Patterns';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nconst getAreaName = (area) => {\n  let name = area.area_name || area.name;\n\n  return name;\n};\n\nconst getAreaId = (area) => {\n  let name = area.area_id || area.id;\n\n  return name;\n};\n\nexport const genericPolygon = (area, mapZoom) => {\n  let areaPolygon: Polygon;\n  let latlngs = area.shape_data.map((location: any) => {\n    return [location['lat'], location['lng']];\n  });\n\n  if (latlngs.length < 1) return;\n\n  let color = area.color ? area.color : scoreToColor(area.area_score);\n\n  areaPolygon = L.polygon(latlngs, {\n    color,\n    fillOpacity: area.showColorOnlyInBorders ? 0.3 : 0.4,\n    weight: area.showColorOnlyInBorders ? 2 : 0,\n    fill: area?.sub_areas?.length > 0 ? false : true,\n  });\n\n  return areaPolygon;\n};\n\nexport const calculatePolygonArea = (coordinates) => {\n  let area = 0;\n  let numPoints = coordinates.length;\n\n  for (let i = 0; i < numPoints; i++) {\n    let x1 = coordinates[i][0];\n    let y1 = coordinates[i][1];\n    let x2 = coordinates[(i + 1) % numPoints][0];\n    let y2 = coordinates[(i + 1) % numPoints][1];\n\n    area += x1 * y2 - x2 * y1;\n  }\n\n  return Math.abs(area / 2);\n};\n\nconst polygonTitle = (area, mapZoom) => {\n  return `<div class=\"area-tooltip\" style=\"color:${\n    theme.colorScheme.primary.ps1\n  };font-weight:700;background-color:transparent;font-size: ${\n    mapZoom * 1.5\n  }px;-webkit-text-stroke: 0.8px #ffffff;\"> ${getAreaName(area)} \n        </div>`;\n};\n\nconst bindTooltip = (layer, area, mapZoom) => {\n  const title = polygonTitle(area, mapZoom);\n  layer.bindTooltip(title, {\n    className: 'area-tooltip',\n    permanent: true,\n    direction: 'center',\n  });\n  handleToltipBasedOnZoomLevel(layer, mapZoom);\n};\n\n// The tooltip is showing the area name\nexport const handleToltipBasedOnZoomLevel = (polygon, mapZoom) => {\n  if (mapZoom > 11) {\n    const tooltip = polygon.getTooltip();\n    tooltip.setContent(polygonTitle(polygon, mapZoom));\n    polygon.openTooltip();\n  } else {\n    polygon.closeTooltip();\n  }\n};\n\nconst drillDownBasedOnZoomLevel = (\n  areaPolygon,\n  area,\n  percentage,\n  zoomPercentageToDrillDown,\n  isPartialPolygonVisible,\n  map,\n  featureGroup,\n) => {\n  const drillDownCondition = () => {\n    return (\n      percentage >= zoomPercentageToDrillDown &&\n      isPartialPolygonVisible &&\n      area.sub_areas.length !== 0 &&\n      areaPolygon._map !== null\n    );\n  };\n\n  const hidePolygon = (polygon: Polygon) => {\n    polygon.bringToBack();\n    polygon.closeTooltip();\n    polygon['hidden'] = true;\n    polygon.setStyle({\n      stroke: false,\n      fill: false,\n    });\n  };\n\n  const showPolygon = (polygon: Polygon, fill: boolean) => {\n    polygon.bringToFront();\n    polygon['hidden'] = false;\n    polygon.setStyle({\n      //stroke: fill ? false : true,\n      stroke: true,\n      opacity: 0.4,\n      weight: 2,\n      fill: fill,\n      fillOpacity: 0.4,\n    });\n  };\n\n  const handleSubAreas = (show: boolean) => {\n    if (areaPolygon['sub_areas'] !== undefined) {\n      areaPolygon['sub_areas'].forEach((subAreaId) => {\n        featureGroup.eachLayer((layer) => {\n          if (layer['kando_object_id'] === subAreaId) {\n            show ? showPolygon(layer, true) : hidePolygon(layer);\n          }\n        });\n      });\n    }\n  };\n\n  // Show the area with border only\n  // Or background color\n  if (drillDownCondition()) {\n    showPolygon(areaPolygon, false);\n    areaPolygon.closeTooltip();\n    handleSubAreas(true);\n  } else {\n    handleSubAreas(false);\n\n    if (!areaPolygon['hidden']) {\n      showPolygon(areaPolygon, true);\n      handleToltipBasedOnZoomLevel(areaPolygon, map.getZoom());\n    }\n  }\n};\n\nexport const zoomControlForArea = (areaPolygon, area, map, featureGroup) => {\n  map.on('zoomend', function () {\n    let getMapBounds = map.getBounds();\n    let polygonBounds = areaPolygon.getBounds();\n    let isPartialPolygonVisible = getMapBounds.intersects(polygonBounds);\n    let mapBoundsPolygon = L.polygon([\n      getMapBounds.getSouthWest(),\n      getMapBounds.getNorthWest(),\n      getMapBounds.getNorthEast(),\n      getMapBounds.getSouthEast(),\n    ]);\n\n    let mapBounds = calculatePolygonArea(\n      mapBoundsPolygon.toGeoJSON().geometry.coordinates[0],\n    );\n\n    let areaSurface = areaPolygon['calculated_surface'];\n    const zoomPercentageToDrillDown = 15.0;\n    const percentage = (areaSurface / mapBounds) * 100;\n\n    drillDownBasedOnZoomLevel(\n      areaPolygon,\n      area,\n      percentage,\n      zoomPercentageToDrillDown,\n      isPartialPolygonVisible,\n      map,\n      featureGroup,\n    );\n  });\n};\n\nconst customAttributesForAreaPolygon = (areaPolygon, area) => {\n  areaPolygon['kando_object_id'] = getAreaId(area);\n  areaPolygon['kando_object'] = 'Area';\n  areaPolygon['area_name'] = getAreaName(area);\n  areaPolygon['calculated_surface'] = area.calculated_surface;\n};\n\nexport const createPolygon = (\n  area,\n  mapZoom,\n  featureGroup: FeatureGroup,\n  map,\n  popupCreator?: (polygon: Polygon, area: IArea) => void,\n) => {\n  let polygon: Polygon;\n  if (\n    area.shape_data !== null &&\n    area.shape_data !== undefined &&\n    area.shape_data.length > 0\n  ) {\n    polygon = genericPolygon(area, mapZoom);\n\n    customAttributesForAreaPolygon(polygon, area);\n    const pattern = getPattern(area);\n    if (pattern) {\n      pattern?.addTo(map);\n      polygon.setStyle({\n        fillPattern: pattern,\n        color: scoreToColor(area.area_score),\n      });\n    }\n    polygon.addTo(featureGroup);\n    popupCreator && popupCreator(polygon, area);\n    bindTooltip(polygon, area, mapZoom);\n    zoomControlForArea(polygon, area, map, featureGroup);\n    return polygon;\n  }\n  return null;\n};\n\nconst getPattern = (area) => {\n  if (area.is_assessment === false) {\n    return null;\n  }\n  const color = scoreToColor(area.area_score);\n  return assesmentPattern(color);\n};\n"],"mappings":"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"}
|
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
const packageJsonVersion = "1.2.354-alpha.
|
|
3
|
+
const packageJsonVersion = "1.2.354-alpha.4";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|