forked from rjsf-team/react-jsonschema-form
/
BaseInputTemplate.tsx
89 lines (87 loc) · 2.43 KB
/
BaseInputTemplate.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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import React from "react";
import { Form } from "semantic-ui-react";
import { getSemanticProps } from "../util";
import {
getInputProps,
FormContextType,
RJSFSchema,
StrictRJSFSchema,
WidgetProps,
} from "@rjsf/utils";
/** The `BaseInputTemplate` is the template to use to render the basic `<input>` component for the `core` theme.
* It is used as the template for rendering many of the <input> based widgets that differ by `type` and callbacks only.
* It can be customized/overridden for other themes or individual implementations as needed.
*
* @param props - The `WidgetProps` for this template
*/
export default function BaseInputTemplate<
T = any,
S extends StrictRJSFSchema = RJSFSchema,
F extends FormContextType = any
>(props: WidgetProps<T, S, F>) {
const {
id,
placeholder,
label,
value,
required,
readonly,
disabled,
onChange,
onBlur,
onFocus,
autofocus,
options,
schema,
uiSchema,
formContext,
type,
registry,
rawErrors = [],
} = props;
const inputProps = getInputProps<T, S, F>(schema, type, options);
const semanticProps = getSemanticProps<T, S, F>({
uiSchema,
formContext,
options,
});
const { schemaUtils } = registry;
const _onChange = ({
target: { value },
}: React.ChangeEvent<HTMLInputElement>) =>
onChange(value === "" ? options.emptyValue : value);
const _onBlur = () => onBlur && onBlur(id, value);
const _onFocus = () => onFocus && onFocus(id, value);
const displayLabel = schemaUtils.getDisplayLabel(schema, uiSchema);
return (
<>
<Form.Input
key={id}
id={id}
name={id}
placeholder={placeholder}
{...inputProps}
label={displayLabel ? label || schema.title : false}
required={required}
autoFocus={autofocus}
disabled={disabled || readonly}
list={schema.examples ? `examples_${id}` : undefined}
{...semanticProps}
value={value || value === 0 ? value : ""}
error={rawErrors.length > 0}
onChange={_onChange}
onBlur={_onBlur}
onFocus={_onFocus}
/>
{schema.examples && (
<datalist id={`examples_${id}`}>
{(schema.examples as string[])
.concat(schema.default ? ([schema.default] as string[]) : [])
.map((example) => {
return <option key={example} value={example} />;
})}
</datalist>
)}
</>
);
}