UNPKG

@vis.gl/react-mapbox

Version:

React components for Mapbox GL JS

61 lines (52 loc) 1.79 kB
import {ImmutableLike} from '../types/common'; import {StyleSpecification} from '../types/style-spec'; 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: string | StyleSpecification | ImmutableLike<StyleSpecification> ): string | StyleSpecification { 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: typeof layer = 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}; }