PteroTheme/resources/scripts/components/forms/OpenInputField.tsx

38 lines
1.0 KiB
TypeScript
Raw Normal View History

import * as React from 'react';
import classNames from 'classnames';
type Props = React.InputHTMLAttributes<HTMLInputElement> & {
label: string;
2019-06-12 06:02:18 +01:00
description?: string;
};
2019-06-16 23:24:20 +01:00
export default React.forwardRef<HTMLInputElement, Props>(({ className, description, onChange, label, ...props }, ref) => {
const [ value, setValue ] = React.useState('');
const classes = classNames('input open-label', {
'has-content': value && value.length > 0,
});
return (
<div className={'input-open'}>
<input
2019-06-16 23:24:20 +01:00
ref={ref}
className={classes}
onChange={e => {
setValue(e.target.value);
if (onChange) {
onChange(e);
}
}}
{...props}
/>
<label htmlFor={props.id}>{label}</label>
2019-06-12 06:02:18 +01:00
{description &&
<p className={'text-xs text-neutral-500'}>
{description}
</p>
}
</div>
);
2019-06-16 23:24:20 +01:00
});