-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcheckbox.tsx
71 lines (65 loc) · 1.79 KB
/
checkbox.tsx
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
import React from 'react';
import {
Checkbox,
CheckboxGroup,
Flex,
FormControl,
FormErrorMessage,
FormLabel
} from '@chakra-ui/react';
import { FastField, FastFieldProps } from 'formik';
import {
SchemaFieldArray,
SchemaFieldString,
WidgetProps
} from '@stac-manager/data-core';
import { FieldLabel } from '../components/elements';
export function WidgetCheckbox(props: WidgetProps) {
const { pointer, isRequired } = props;
const field = props.field as SchemaFieldArray<SchemaFieldString>;
const options = field.items.enum;
if (field.items.allowOther) {
throw new Error(
"WidgetCheckbox: allowOther is not supported. Use widget 'tagger' instead"
);
}
if (!options?.length) {
throw new Error('WidgetCheckbox: items.enum is required');
}
return (
<FastField name={pointer}>
{({
field: { value },
meta,
form: { setFieldValue, setFieldTouched }
}: FastFieldProps) => (
<FormControl
isRequired={isRequired}
isInvalid={!!(meta.touched && meta.error)}
>
{field.label && (
<FormLabel>
<FieldLabel size='xs'>{field.label}</FieldLabel>
</FormLabel>
)}
<Flex gap={4}>
<CheckboxGroup
value={value}
onChange={(v) => {
setFieldValue(pointer, v);
setFieldTouched(pointer, true);
}}
>
{options.map(([checkboxVal, label]) => (
<Checkbox key={checkboxVal} size='sm' value={checkboxVal}>
{label}
</Checkbox>
))}
</CheckboxGroup>
</Flex>
<FormErrorMessage>{meta.error}</FormErrorMessage>
</FormControl>
)}
</FastField>
);
}