@mapbox/mapbox-gl-style-spec
Version:
a specification for mapbox gl styles
61 lines (53 loc) • 2.1 kB
text/typescript
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;
}