Demos
Empty
<DataInput.String onChange={(value) => console.log('onChange', value)} />
Placeholder
<DataInput.Stringplaceholder="Enter a text..."onChange={(value) => console.log('onChange', value)}/>
Label
<DataInput.Stringlabel="Label text"onChange={(value) => console.log('onChange', value)}/>
Label and value
<DataInput.Stringlabel="Label text"value="foo"onChange={(value) => console.log('onChange', value)}/>
Icon, left side
<DataInput.Stringvalue="foo"leftIcon="check"onChange={(value) => console.log('onChange', value)}/>
Icon, right side
<DataInput.Stringvalue="foo"rightIcon="loupe"onChange={(value) => console.log('onChange', value)}/>
Character counter
 0
<DataInput.StringonChange={(value) => console.log('onChange', value)}characterCounter/>
3
<DataInput.Stringlabel="Label text"value="foo"onChange={(value) => console.log('onChange', value)}characterCounter/>
3/16
<DataInput.Stringlabel="Label text"value="foo"onChange={(value) => console.log('onChange', value)}maxLength={16}characterCounter/>
Clear
<DataInput.Stringvalue="foo"onChange={(value) => console.log('onChange', value)}clear/>
Disabled
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}disabled/>
Info
Useful information (?)
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}info="Useful information (?)"/>
Warning
I'm warning you...
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}warning={new FormError("I'm warning you...")}/>
Error
This is what is wrong...
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}error={new FormError('This is what is wrong...')}/>
Validation - Required
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}required/>
Validation - Minimum length
<DataInput.Stringvalue="foo"label="Label text (minimum 8 characters)"onChange={(value) => console.log('onChange', value)}minLength={8}/>
Validation - Maximum length and custom error message
<DataInput.Stringvalue="foo"label="Label text (maximum 8 characters)"onChange={(value) => console.log('onChange', value)}maxLength={8}errorMessages={{maxLength: "You can't write THAT long.. Max 8 chars!",}}/>
Validation - Pattern
<DataInput.Stringvalue="foo"label="Label text"onChange={(value) => console.log('onChange', value)}pattern="^foo123"/>
Synchronous external validator (called on every change)
<DataInput.Stringvalue="foo"label="Label text (minimum 4 characters)"validator={(value) =>value.length < 4 ? new FormError('At least 4 characters') : undefined}onChange={(value) => console.log('onChange', value)}/>
Asynchronous external validator (called on every change)
<DataInput.Stringvalue="foo"label="Label text (minimum 4 characters)"validator={(value) =>new Promise((resolve) =>setTimeout(() =>resolve(value.length < 5? new FormError('At least 5 characters'): undefined),1500))}onChange={(value) => console.log('onChange', value)}/>
Synchronous external validator (called on blur)
<DataInput.Stringvalue="foo"label="Label text (minimum 4 characters)"onBlurValidator={(value) =>value.length < 4 ? new FormError('At least 4 characters') : undefined}onChange={(value) => console.log('onChange', value)}/>
Asynchronous external validator (called on blur)
<DataInput.Stringvalue="foo"label="Label text (minimum 4 characters)"onBlurValidator={(value) =>new Promise((resolve) =>setTimeout(() =>resolve(value.length < 5? new FormError('At least 5 characters'): undefined),1500))}onChange={(value) => console.log('onChange', value)}/>
Multiline, empty
<DataInput.StringonChange={(value) => console.log('onChange', value)}multiline/>
Multiline, placeholder
<DataInput.Stringplaceholder="Enter text here"onChange={(value) => console.log('onChange', value)}multiline/>
Multiline, label & value
<DataInput.Stringvalue="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis in tempus odio, nec interdum orci. Integer vehicula ipsum et risus finibus, vitae commodo ex luctus. Nam viverra sollicitudin dictum. Vivamus maximus dignissim lorem, vitae viverra erat dapibus a."label="Label text"onChange={(value) => console.log('onChange', value)}multiline/>