kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
235 lines (224 loc) • 40.2 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = PlotContainerFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactMapGl = require("react-map-gl");
var _debounce = _interopRequireDefault(require("lodash/debounce"));
var _utils = require("@kepler.gl/utils");
var _reducers = require("@kepler.gl/reducers");
var _mapContainer = _interopRequireDefault(require("./map-container"));
var _mapsLayout = _interopRequireDefault(require("./maps-layout"));
var _mapViewStateContext = require("./map-view-state-context");
var _constants = require("@kepler.gl/constants");
var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
// libraries
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var CLASS_FILTER = ['maplibregl-control-container', 'mapboxgl-control-container', 'attrition-link', 'attrition-logo', 'map-control__panel-split-viewport-tools'];
var DOM_FILTER_FUNC = function DOM_FILTER_FUNC(node) {
return !CLASS_FILTER.includes(node.className);
};
var OUT_OF_SCREEN_POSITION = -9999;
PlotContainerFactory.deps = [_mapContainer["default"], _mapsLayout["default"]];
// Remove mapbox logo in exported map, because it contains non-ascii characters
// Remove split viewport UI controls from exported images when the legend is shown
var StyledPlotContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .maplibregl-ctrl-bottom-left,\n .maplibregl-ctrl-bottom-right,\n .maplibre-attribution-container,\n .mapboxgl-ctrl-bottom-left,\n .mapboxgl-ctrl-bottom-right,\n .mapbox-attribution-container,\n .map-control__panel-split-viewport-tools {\n display: none;\n }\n\n position: absolute;\n top: ", "px;\n left: ", "px;\n"])), OUT_OF_SCREEN_POSITION, OUT_OF_SCREEN_POSITION);
var StyledMapContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", "px;\n height: ", "px;\n display: flex;\n"])), function (props) {
return props.width;
}, function (props) {
return props.height;
});
function PlotContainerFactory(MapContainer, MapsLayout) {
function PlotContainer(_ref) {
var ratio = _ref.ratio,
resolution = _ref.resolution,
_ref$legend = _ref.legend,
legend = _ref$legend === void 0 ? false : _ref$legend,
center = _ref.center,
imageSize = _ref.imageSize,
escapeXhtmlForWebpack = _ref.escapeXhtmlForWebpack,
mapFields = _ref.mapFields,
_ref$splitMaps = _ref.splitMaps,
splitMaps = _ref$splitMaps === void 0 ? [] : _ref$splitMaps,
setExportImageSetting = _ref.setExportImageSetting,
setExportImageDataUri = _ref.setExportImageDataUri,
setExportImageError = _ref.setExportImageError,
addNotification = _ref.addNotification,
enableErrorNotification = _ref.enableErrorNotification;
var plottingAreaRef = (0, _react.useRef)(null);
var _useState = (0, _react.useState)(function () {
return mapFields.visState.effects.map(function (effect) {
return effect.clone();
});
}),
_useState2 = (0, _slicedToArray2["default"])(_useState, 1),
plotEffects = _useState2[0];
var mapState = mapFields.mapState;
// Memoize the scale calculation
var scale = (0, _react.useMemo)(function () {
if (imageSize.scale) {
return imageSize.scale;
}
var calculatedScale = (0, _utils.getScaleFromImageSize)(imageSize.imageW, imageSize.imageH, mapState.width * (mapState.isSplit ? 2 : 1), mapState.height);
return calculatedScale > 0 ? calculatedScale : 1;
}, [imageSize.scale, imageSize.imageW, imageSize.imageH, mapState.width, mapState.height, mapState.isSplit]);
// Memoize the map style
var scaledMapStyle = (0, _react.useMemo)(function () {
var mapStyle = mapFields.mapStyle;
return _objectSpread(_objectSpread({}, mapStyle), {}, {
bottomMapStyle: (0, _utils.scaleMapStyleByResolution)(mapStyle.bottomMapStyle, scale),
topMapStyle: (0, _utils.scaleMapStyleByResolution)(mapStyle.topMapStyle, scale)
});
}, [mapFields.mapStyle, scale]);
// Memoize the retrieveNewScreenshot callback
var debouncedScreenshot = (0, _react.useMemo)(function () {
return (0, _debounce["default"])(function () {
if (plottingAreaRef.current) {
(0, _utils.convertToPng)(plottingAreaRef.current, {
filter: DOM_FILTER_FUNC,
width: imageSize.imageW,
height: imageSize.imageH,
escapeXhtmlForWebpack: escapeXhtmlForWebpack
}).then(setExportImageDataUri)["catch"](function (err) {
setExportImageError(err);
if (enableErrorNotification) {
addNotification((0, _utils.exportImageError)({
err: err
}));
}
});
}
}, 500);
}, [imageSize.imageW, imageSize.imageH, escapeXhtmlForWebpack, setExportImageDataUri, setExportImageError, enableErrorNotification, addNotification]);
var retrieveNewScreenshot = (0, _react.useCallback)(debouncedScreenshot, [debouncedScreenshot]);
// Memoize the onMapRender callback
var debouncedMapRender = (0, _react.useMemo)(function () {
return (0, _debounce["default"])(function (map) {
if (map.isStyleLoaded()) {
retrieveNewScreenshot();
}
}, 500);
}, [retrieveNewScreenshot]);
var onMapRender = (0, _react.useCallback)(debouncedMapRender, [debouncedMapRender]);
// Initial setup effect
(0, _react.useEffect)(function () {
setExportImageSetting({
processing: true
});
}, [setExportImageSetting]);
// Screenshot update effect
(0, _react.useEffect)(function () {
if (ratio !== undefined || resolution !== undefined || legend !== undefined) {
setExportImageSetting({
processing: true
});
retrieveNewScreenshot();
}
}, [ratio, resolution, legend, setExportImageSetting, retrieveNewScreenshot]);
// Memoize size calculations
var _useMemo = (0, _react.useMemo)(function () {
var size = {
width: imageSize.imageW || 1,
height: imageSize.imageH || 1
};
var isSplit = splitMaps.length > 1;
return {
size: size,
width: size.width / (isSplit ? 2 : 1),
height: size.height
};
}, [imageSize.imageW, imageSize.imageH, splitMaps.length]),
size = _useMemo.size,
width = _useMemo.width,
height = _useMemo.height;
// Memoize map state
var newMapState = (0, _react.useMemo)(function () {
var baseMapState = _objectSpread(_objectSpread({}, mapState), {}, {
width: width,
height: height,
zoom: mapState.zoom + (Math.log2(scale) || 0)
});
if (center) {
var renderedLayers = mapFields.visState.layers.filter(function (layer, idx) {
return layer.id !== _constants.GEOCODER_LAYER_ID && layer.shouldRenderLayer(mapFields.visState.layerData[idx]);
});
var bounds = (0, _reducers.findMapBounds)(renderedLayers);
var centerAndZoom = (0, _utils.getCenterAndZoomFromBounds)(bounds, {
width: width,
height: height
});
if (centerAndZoom) {
var zoom = Number.isFinite(centerAndZoom.zoom) ? centerAndZoom.zoom : mapState.zoom;
return _objectSpread(_objectSpread({}, baseMapState), {}, {
longitude: centerAndZoom.center[0],
latitude: centerAndZoom.center[1],
zoom: zoom + Number(Math.log2(scale) || 0)
});
}
}
return baseMapState;
}, [mapState, width, height, scale, center, mapFields.visState]);
// Memoize map props
var mapProps = (0, _react.useMemo)(function () {
return _objectSpread(_objectSpread({}, mapFields), {}, {
mapStyle: scaledMapStyle,
mapState: newMapState,
mapControls: {
mapLegend: {
show: Boolean(legend),
active: true
}
},
MapComponent: _reactMapGl.Map,
onMapRender: onMapRender,
isExport: true,
deckGlProps: _objectSpread(_objectSpread({}, mapFields.deckGlProps), {}, {
glOptions: {
preserveDrawingBuffer: true,
useDevicePixels: false
}
}),
visState: _objectSpread(_objectSpread({}, mapFields.visState), {}, {
effects: plotEffects
})
});
}, [mapFields, scaledMapStyle, newMapState, legend, onMapRender, plotEffects]);
var isSplit = splitMaps.length > 1;
var mapContainers = !isSplit ? /*#__PURE__*/_react["default"].createElement(MapContainer, (0, _extends2["default"])({
index: 0,
primary: true
}, mapProps)) : /*#__PURE__*/_react["default"].createElement(MapsLayout, {
className: "plot-container-maps",
mapState: newMapState
}, splitMaps.map(function (settings, index) {
return /*#__PURE__*/_react["default"].createElement(MapContainer, (0, _extends2["default"])({
key: index,
index: index,
primary: index === 1
}, mapProps));
}));
return /*#__PURE__*/_react["default"].createElement(StyledPlotContainer, {
className: "export-map-instance"
}, /*#__PURE__*/_react["default"].createElement(StyledMapContainer, {
ref: plottingAreaRef,
width: size.width,
height: size.height
}, /*#__PURE__*/_react["default"].createElement(_mapViewStateContext.MapViewStateContextProvider, {
mapState: newMapState
}, mapContainers)));
}
return /*#__PURE__*/_react["default"].memo(PlotContainer);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_reactMapGl","_debounce","_utils","_reducers","_mapContainer","_mapsLayout","_mapViewStateContext","_constants","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","CLASS_FILTER","DOM_FILTER_FUNC","node","includes","className","OUT_OF_SCREEN_POSITION","PlotContainerFactory","deps","MapContainerFactory","MapsLayoutFactory","StyledPlotContainer","styled","div","_taggedTemplateLiteral2","StyledMapContainer","props","width","height","MapContainer","MapsLayout","PlotContainer","_ref","ratio","resolution","_ref$legend","legend","center","imageSize","escapeXhtmlForWebpack","mapFields","_ref$splitMaps","splitMaps","setExportImageSetting","setExportImageDataUri","setExportImageError","addNotification","enableErrorNotification","plottingAreaRef","useRef","_useState","useState","visState","effects","map","effect","clone","_useState2","_slicedToArray2","plotEffects","mapState","scale","useMemo","calculatedScale","getScaleFromImageSize","imageW","imageH","isSplit","scaledMapStyle","mapStyle","bottomMapStyle","scaleMapStyleByResolution","topMapStyle","debouncedScreenshot","debounce","current","convertToPng","then","err","exportImageError","retrieveNewScreenshot","useCallback","debouncedMapRender","isStyleLoaded","onMapRender","useEffect","processing","undefined","_useMemo","size","newMapState","baseMapState","zoom","Math","log2","renderedLayers","layers","layer","idx","id","GEOCODER_LAYER_ID","shouldRenderLayer","layerData","bounds","findMapBounds","centerAndZoom","getCenterAndZoomFromBounds","Number","isFinite","longitude","latitude","mapProps","mapControls","mapLegend","show","Boolean","active","MapComponent","Map","isExport","deckGlProps","glOptions","preserveDrawingBuffer","useDevicePixels","mapContainers","createElement","_extends2","index","primary","settings","key","ref","MapViewStateContextProvider","React","memo"],"sources":["../src/plot-container.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// libraries\nimport React, {useRef, useEffect, useState, useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport {Map} from 'react-map-gl';\nimport debounce from 'lodash/debounce';\nimport {\n  exportImageError,\n  scaleMapStyleByResolution,\n  getCenterAndZoomFromBounds,\n  convertToPng,\n  getScaleFromImageSize\n} from '@kepler.gl/utils';\nimport {findMapBounds} from '@kepler.gl/reducers';\nimport MapContainerFactory from './map-container';\nimport MapsLayoutFactory from './maps-layout';\nimport {MapViewStateContextProvider} from './map-view-state-context';\n\nimport {GEOCODER_LAYER_ID} from '@kepler.gl/constants';\nimport {Effect, SplitMap, ExportImage} from '@kepler.gl/types';\nimport {\n  ActionHandler,\n  addNotification,\n  setExportImageDataUri,\n  setExportImageError,\n  setExportImageSetting\n} from '@kepler.gl/actions';\nimport {mapFieldsSelector} from './kepler-gl';\n\nconst CLASS_FILTER = [\n  'maplibregl-control-container',\n  'mapboxgl-control-container',\n  'attrition-link',\n  'attrition-logo',\n  'map-control__panel-split-viewport-tools'\n];\nconst DOM_FILTER_FUNC = node => !CLASS_FILTER.includes(node.className);\nconst OUT_OF_SCREEN_POSITION = -9999;\n\nPlotContainerFactory.deps = [MapContainerFactory, MapsLayoutFactory];\n\n// Remove mapbox logo in exported map, because it contains non-ascii characters\n// Remove split viewport UI controls from exported images when the legend is shown\nconst StyledPlotContainer = styled.div`\n  .maplibregl-ctrl-bottom-left,\n  .maplibregl-ctrl-bottom-right,\n  .maplibre-attribution-container,\n  .mapboxgl-ctrl-bottom-left,\n  .mapboxgl-ctrl-bottom-right,\n  .mapbox-attribution-container,\n  .map-control__panel-split-viewport-tools {\n    display: none;\n  }\n\n  position: absolute;\n  top: ${OUT_OF_SCREEN_POSITION}px;\n  left: ${OUT_OF_SCREEN_POSITION}px;\n`;\n\ninterface StyledMapContainerProps {\n  width?: number;\n  height?: number;\n}\n\nconst StyledMapContainer = styled.div<StyledMapContainerProps>`\n  width: ${props => props.width}px;\n  height: ${props => props.height}px;\n  display: flex;\n`;\n\ninterface PlotContainerProps {\n  // Image export settings\n  ratio?: string;\n  resolution?: string;\n  legend?: boolean;\n  center?: boolean;\n  imageSize: ExportImage['imageSize'];\n  escapeXhtmlForWebpack?: boolean;\n\n  // Map settings\n  mapFields: ReturnType<typeof mapFieldsSelector>;\n  splitMaps?: SplitMap[];\n\n  // Callbacks\n  setExportImageSetting: typeof setExportImageSetting;\n  setExportImageDataUri: typeof setExportImageDataUri;\n  setExportImageError: typeof setExportImageError;\n  addNotification: ActionHandler<typeof addNotification>;\n\n  // Flags\n  enableErrorNotification?: boolean;\n}\n\nexport default function PlotContainerFactory(\n  MapContainer: ReturnType<typeof MapContainerFactory>,\n  MapsLayout: ReturnType<typeof MapsLayoutFactory>\n): React.ComponentType<PlotContainerProps> {\n  function PlotContainer({\n    // Image export settings\n    ratio,\n    resolution,\n    legend = false,\n    center,\n    imageSize,\n    escapeXhtmlForWebpack,\n\n    // Map settings\n    mapFields,\n    splitMaps = [],\n\n    // Callbacks\n    setExportImageSetting,\n    setExportImageDataUri,\n    setExportImageError,\n    addNotification,\n\n    // Flags\n    enableErrorNotification\n  }: PlotContainerProps) {\n    const plottingAreaRef = useRef<HTMLDivElement>(null);\n    const [plotEffects] = useState<Effect[]>(() =>\n      mapFields.visState.effects.map(effect => effect.clone())\n    );\n\n    const {mapState} = mapFields;\n\n    // Memoize the scale calculation\n    const scale = useMemo(() => {\n      if (imageSize.scale) {\n        return imageSize.scale;\n      }\n\n      const calculatedScale = getScaleFromImageSize(\n        imageSize.imageW,\n        imageSize.imageH,\n        mapState.width * (mapState.isSplit ? 2 : 1),\n        mapState.height\n      );\n\n      return calculatedScale > 0 ? calculatedScale : 1;\n    }, [\n      imageSize.scale,\n      imageSize.imageW,\n      imageSize.imageH,\n      mapState.width,\n      mapState.height,\n      mapState.isSplit\n    ]);\n\n    // Memoize the map style\n    const scaledMapStyle = useMemo(() => {\n      const mapStyle = mapFields.mapStyle;\n      return {\n        ...mapStyle,\n        bottomMapStyle: scaleMapStyleByResolution(mapStyle.bottomMapStyle, scale),\n        topMapStyle: scaleMapStyleByResolution(mapStyle.topMapStyle, scale)\n      };\n    }, [mapFields.mapStyle, scale]);\n\n    // Memoize the retrieveNewScreenshot callback\n    const debouncedScreenshot = useMemo(\n      () =>\n        debounce(() => {\n          if (plottingAreaRef.current) {\n            convertToPng(plottingAreaRef.current, {\n              filter: DOM_FILTER_FUNC,\n              width: imageSize.imageW,\n              height: imageSize.imageH,\n              escapeXhtmlForWebpack\n            })\n              .then(setExportImageDataUri)\n              .catch(err => {\n                setExportImageError(err);\n                if (enableErrorNotification) {\n                  addNotification(exportImageError({err}));\n                }\n              });\n          }\n        }, 500),\n      [\n        imageSize.imageW,\n        imageSize.imageH,\n        escapeXhtmlForWebpack,\n        setExportImageDataUri,\n        setExportImageError,\n        enableErrorNotification,\n        addNotification\n      ]\n    );\n\n    const retrieveNewScreenshot = useCallback(debouncedScreenshot, [debouncedScreenshot]);\n\n    // Memoize the onMapRender callback\n    const debouncedMapRender = useMemo(\n      () =>\n        debounce(map => {\n          if (map.isStyleLoaded()) {\n            retrieveNewScreenshot();\n          }\n        }, 500),\n      [retrieveNewScreenshot]\n    );\n\n    const onMapRender = useCallback(debouncedMapRender, [debouncedMapRender]);\n\n    // Initial setup effect\n    useEffect(() => {\n      setExportImageSetting({processing: true});\n    }, [setExportImageSetting]);\n\n    // Screenshot update effect\n    useEffect(() => {\n      if (ratio !== undefined || resolution !== undefined || legend !== undefined) {\n        setExportImageSetting({processing: true});\n        retrieveNewScreenshot();\n      }\n    }, [ratio, resolution, legend, setExportImageSetting, retrieveNewScreenshot]);\n\n    // Memoize size calculations\n    const {size, width, height} = useMemo(() => {\n      const size = {\n        width: imageSize.imageW || 1,\n        height: imageSize.imageH || 1\n      };\n      const isSplit = splitMaps.length > 1;\n      return {\n        size,\n        width: size.width / (isSplit ? 2 : 1),\n        height: size.height\n      };\n    }, [imageSize.imageW, imageSize.imageH, splitMaps.length]);\n\n    // Memoize map state\n    const newMapState = useMemo(() => {\n      const baseMapState = {\n        ...mapState,\n        width,\n        height,\n        zoom: mapState.zoom + (Math.log2(scale) || 0)\n      };\n\n      if (center) {\n        const renderedLayers = mapFields.visState.layers.filter(\n          (layer, idx) =>\n            layer.id !== GEOCODER_LAYER_ID &&\n            layer.shouldRenderLayer(mapFields.visState.layerData[idx])\n        );\n        const bounds = findMapBounds(renderedLayers);\n        const centerAndZoom = getCenterAndZoomFromBounds(bounds, {width, height});\n        if (centerAndZoom) {\n          const zoom = Number.isFinite(centerAndZoom.zoom) ? centerAndZoom.zoom : mapState.zoom;\n          return {\n            ...baseMapState,\n            longitude: centerAndZoom.center[0],\n            latitude: centerAndZoom.center[1],\n            zoom: zoom + Number(Math.log2(scale) || 0)\n          };\n        }\n      }\n\n      return baseMapState;\n    }, [mapState, width, height, scale, center, mapFields.visState]);\n\n    // Memoize map props\n    const mapProps = useMemo(\n      () => ({\n        ...mapFields,\n        mapStyle: scaledMapStyle,\n        mapState: newMapState,\n        mapControls: {\n          mapLegend: {\n            show: Boolean(legend),\n            active: true\n          }\n        },\n        MapComponent: Map,\n        onMapRender,\n        isExport: true,\n        deckGlProps: {\n          ...mapFields.deckGlProps,\n          glOptions: {\n            preserveDrawingBuffer: true,\n            useDevicePixels: false\n          }\n        },\n        visState: {\n          ...mapFields.visState,\n          effects: plotEffects\n        }\n      }),\n      [mapFields, scaledMapStyle, newMapState, legend, onMapRender, plotEffects]\n    );\n\n    const isSplit = splitMaps.length > 1;\n    const mapContainers = !isSplit ? (\n      <MapContainer index={0} primary={true} {...mapProps} />\n    ) : (\n      <MapsLayout className=\"plot-container-maps\" mapState={newMapState}>\n        {splitMaps.map((settings, index) => (\n          <MapContainer key={index} index={index} primary={index === 1} {...mapProps} />\n        ))}\n      </MapsLayout>\n    );\n\n    return (\n      <StyledPlotContainer className=\"export-map-instance\">\n        <StyledMapContainer ref={plottingAreaRef} width={size.width} height={size.height}>\n          <MapViewStateContextProvider mapState={newMapState}>\n            {mapContainers}\n          </MapViewStateContextProvider>\n        </StyledMapContainer>\n      </StyledPlotContainer>\n    );\n  }\n\n  return React.memo(PlotContainer);\n}\n"],"mappings":"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","ignoreList":[]}
;