1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
import slugify from '@sindresorhus/slugify';
import { translatedErrors } from '@strapi/admin/strapi-admin';
import * as yup from 'yup';
const GRAPHQL_ENUM_REGEX = /^[_A-Za-z][_0-9A-Za-z]*$/;
const toRegressedEnumValue = (value?: string) => {
if (!value) {
return '';
}
return slugify(value, {
decamelize: false,
lowercase: false,
separator: '_',
});
};
const hasUniqueValues = (values: string[]) => {
const seen = new Set<string>();
for (const value of values) {
if (seen.has(value)) {
return false;
}
seen.add(value);
}
return true;
};
export const checkboxListOptionsValidator = () => ({
enum: yup
.array()
.of(yup.string())
.min(1, translatedErrors.min.id)
.test({
name: 'areEnumValuesUnique',
message: 'content-type-builder.error.validation.enum-duplicate',
test(values) {
if (!values) {
return false;
}
const normalizedValues = values.map(toRegressedEnumValue);
return hasUniqueValues(normalizedValues);
},
})
.test({
name: 'doesNotHaveEmptyValues',
message: 'content-type-builder.error.validation.enum-empty-string',
test(values) {
if (!values) {
return false;
}
return !values.map(toRegressedEnumValue).some((value) => value === '');
},
})
.test({
name: 'doesMatchRegex',
message: 'content-type-builder.error.validation.enum-regex',
test(values) {
if (!values) {
return false;
}
return values.map(toRegressedEnumValue).every((value) => GRAPHQL_ENUM_REGEX.test(value));
},
}),
enumName: yup.string().nullable(),
});
|