UNPKG

react-map-gl

Version:

React components for MapLibre GL JS and Mapbox GL JS

49 lines 1.78 kB
const refProps = ['type', 'source', 'source-layer', 'minzoom', 'maxzoom', 'filter', 'layout']; // Prepare a map style object for diffing // If immutable - convert to plain object // Work around some issues in older styles that would fail Mapbox's diffing export function normalizeStyle(style) { if (!style) { return null; } if (typeof style === 'string') { return style; } if ('toJS' in style) { style = style.toJS(); } if (!style.layers) { return style; } const layerIndex = {}; for (const layer of style.layers) { layerIndex[layer.id] = layer; } const layers = style.layers.map(layer => { let normalizedLayer = null; if ('interactive' in layer) { normalizedLayer = Object.assign({}, layer); // Breaks style diffing :( // @ts-ignore legacy field not typed delete normalizedLayer.interactive; } // Style diffing doesn't work with refs so expand them out manually before diffing. // @ts-ignore legacy field not typed const layerRef = layerIndex[layer.ref]; if (layerRef) { normalizedLayer = normalizedLayer || Object.assign({}, layer); // @ts-ignore delete normalizedLayer.ref; // https://github.com/mapbox/mapbox-gl-js/blob/master/src/style-spec/deref.js for (const propName of refProps) { if (propName in layerRef) { normalizedLayer[propName] = layerRef[propName]; } } } return normalizedLayer || layer; }); // Do not mutate the style object provided by the user return { ...style, layers }; } //# sourceMappingURL=style-utils.js.map