UNPKG

@mapbox/mapbox-gl-style-spec

Version:

a specification for mapbox gl styles

61 lines (53 loc) 2.1 kB
import ValidationError from '../error/validation_error'; import getType from '../util/get_type'; import validate from './validate'; import type {ValidationOptions} from './validate'; export default function validateLight(options: ValidationOptions): Array<ValidationError> { const light = options.value; const styleSpec = options.styleSpec; const lightSpec = styleSpec.light; const style = options.style; let errors = []; const rootType = getType(light); if (light === undefined) { // eslint-disable-next-line @typescript-eslint/no-unsafe-return return errors; } else if (rootType !== 'object') { errors = errors.concat([new ValidationError('light', light, `object expected, ${rootType} found`)]); // eslint-disable-next-line @typescript-eslint/no-unsafe-return return errors; } for (const key in light) { const transitionMatch = key.match(/^(.*)-transition$/); const useThemeMatch = key.match(/^(.*)-use-theme$/); if (useThemeMatch && lightSpec[useThemeMatch[1]]) { errors = errors.concat(validate({ key, value: light[key], valueSpec: {type: 'string'}, style, styleSpec })); } else if (transitionMatch && lightSpec[transitionMatch[1]] && lightSpec[transitionMatch[1]].transition) { errors = errors.concat(validate({ key, value: light[key], valueSpec: styleSpec.transition, style, styleSpec })); } else if (lightSpec[key]) { errors = errors.concat(validate({ key, value: light[key], valueSpec: lightSpec[key], style, styleSpec })); } else { errors = errors.concat([new ValidationError(key, light[key], `unknown property "${key}"`)]); } } // eslint-disable-next-line @typescript-eslint/no-unsafe-return return errors; }