mirror of
https://github.com/yldio/copilot.git
synced 2025-01-08 01:50:13 +02:00
135 lines
2.8 KiB
JavaScript
135 lines
2.8 KiB
JavaScript
const React = require('react');
|
|
const Styled = require('styled-components');
|
|
const Proxy = require('./redux-form-proxy');
|
|
|
|
const {
|
|
default: styled
|
|
} = Styled;
|
|
|
|
const Label = styled.label`
|
|
color: #464646;
|
|
`;
|
|
|
|
const Error = styled.label`
|
|
color: red;
|
|
float: right;
|
|
`;
|
|
|
|
const InputField = styled.input`
|
|
margin-bottom: 15px;
|
|
background: #FFFFFF;
|
|
display: block;
|
|
font-size: 16px;
|
|
height: 50px;
|
|
padding-left: 15px;
|
|
padding-right: 15px;
|
|
visibility: visible;
|
|
width: 100%;
|
|
|
|
border: 1px solid #3B46CC;
|
|
border-radius: 4px;
|
|
box-shadow: inset 0 3px 0 0 rgba(0, 0, 0, 0.05);
|
|
|
|
&:focus {
|
|
border-color: 1px solid #3B46CC;
|
|
outline: none;
|
|
}
|
|
`;
|
|
|
|
const Input = ({
|
|
autoComplete,
|
|
autoFocus,
|
|
children,
|
|
className,
|
|
disabled = false,
|
|
form,
|
|
id,
|
|
inputMode,
|
|
label,
|
|
labelledby,
|
|
list,
|
|
name,
|
|
onChange,
|
|
onFocus,
|
|
onBlur,
|
|
pattern,
|
|
placeholder,
|
|
readOnly,
|
|
required,
|
|
selectionDirection,
|
|
spellCheck,
|
|
style,
|
|
tabIndex,
|
|
type,
|
|
value,
|
|
touched,
|
|
valid,
|
|
error
|
|
}) => {
|
|
const _label = label || children;
|
|
const _children = label && children ? children : null;
|
|
|
|
return (
|
|
<div>
|
|
<Label htmlFor={id}>
|
|
{_label}
|
|
</Label>
|
|
{ touched && !valid && error && <Error>{error}</Error>}
|
|
<InputField
|
|
aria-labelledby={labelledby}
|
|
autoComplete={autoComplete}
|
|
autoFocus={autoFocus}
|
|
disabled={disabled}
|
|
form={form}
|
|
id={id}
|
|
inputMode={inputMode}
|
|
list={list}
|
|
name={name}
|
|
onChange={onChange}
|
|
onFocus={onFocus}
|
|
onBlur={onBlur}
|
|
pattern={pattern}
|
|
placeholder={placeholder}
|
|
readOnly={readOnly}
|
|
required={required}
|
|
selectionDirection={selectionDirection}
|
|
spellCheck={spellCheck}
|
|
tabIndex={tabIndex}
|
|
type={type}
|
|
value={value}
|
|
/>
|
|
{_children}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
Input.propTypes = {
|
|
autoComplete: React.PropTypes.string,
|
|
autoFocus: React.PropTypes.bool,
|
|
children: React.PropTypes.node,
|
|
className: React.PropTypes.string,
|
|
disabled: React.PropTypes.bool,
|
|
form: React.PropTypes.string,
|
|
id: React.PropTypes.string,
|
|
inputMode: React.PropTypes.string,
|
|
label: React.PropTypes.string,
|
|
labelledby: React.PropTypes.string,
|
|
list: React.PropTypes.string,
|
|
name: React.PropTypes.string,
|
|
onChange: React.PropTypes.func,
|
|
onFocus: React.PropTypes.func,
|
|
onBlur: React.PropTypes.func,
|
|
pattern: React.PropTypes.string,
|
|
placeholder: React.PropTypes.string,
|
|
readOnly: React.PropTypes.bool,
|
|
required: React.PropTypes.bool,
|
|
selectionDirection: React.PropTypes.string,
|
|
spellCheck: React.PropTypes.bool,
|
|
style: React.PropTypes.object,
|
|
tabIndex: React.PropTypes.string,
|
|
type: React.PropTypes.string,
|
|
value: React.PropTypes.string
|
|
};
|
|
|
|
module.exports = Proxy(Input);
|