2021-06-09 09:24:39 +02:00
|
|
|
import React, { BaseSyntheticEvent, ReactNode } from 'react';
|
2021-01-26 11:37:05 +01:00
|
|
|
|
|
|
|
interface LabelledInputProps {
|
|
|
|
id: string,
|
2021-06-08 16:32:19 +02:00
|
|
|
type?: 'text' | 'date' | 'password' | 'url' | 'time' | 'tel' | 'search' | 'number' | 'month' | 'email' | 'datetime-local' | 'week',
|
2021-06-09 09:24:39 +02:00
|
|
|
label: string | ReactNode,
|
2021-01-26 11:37:05 +01:00
|
|
|
value: any,
|
2021-06-08 16:32:19 +02:00
|
|
|
onChange: (event: BaseSyntheticEvent) => void
|
2021-01-26 11:37:05 +01:00
|
|
|
}
|
|
|
|
|
2021-04-07 16:21:12 +02:00
|
|
|
/**
|
|
|
|
* This component shows input field with its label, styled
|
|
|
|
*/
|
2021-01-26 11:37:05 +01:00
|
|
|
export const LabelledInput: React.FC<LabelledInputProps> = ({ id, type, label, value, onChange }) => {
|
|
|
|
return (
|
|
|
|
<div className="input-with-label">
|
|
|
|
<label className="label" htmlFor={id}>{label}</label>
|
|
|
|
<input className="input" id={id} type={type} value={value} onChange={onChange} />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|