44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { colors } from '@0xproject/react-shared';
 | |
| import * as React from 'react';
 | |
| import { styled } from 'ts/style/theme';
 | |
| 
 | |
| export interface InputProps {
 | |
|     className?: string;
 | |
|     value?: string;
 | |
|     width?: string;
 | |
|     fontSize?: string;
 | |
|     fontColor?: string;
 | |
|     placeholderColor?: string;
 | |
|     placeholder?: string;
 | |
|     backgroundColor?: string;
 | |
|     onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;
 | |
| }
 | |
| 
 | |
| const PlainInput: React.StatelessComponent<InputProps> = ({ value, className, placeholder, onChange }) => (
 | |
|     <input className={className} value={value} onChange={onChange} placeholder={placeholder} />
 | |
| );
 | |
| 
 | |
| export const Input = styled(PlainInput)`
 | |
|     font-size: ${props => props.fontSize};
 | |
|     width: ${props => props.width};
 | |
|     padding: 0.8em 1.2em;
 | |
|     border-radius: 3px;
 | |
|     font-family: 'Roboto Mono';
 | |
|     color: ${props => props.fontColor};
 | |
|     border: none;
 | |
|     background-color: ${props => props.backgroundColor};
 | |
|     &::placeholder {
 | |
|         color: ${props => props.placeholderColor};
 | |
|     }
 | |
| `;
 | |
| 
 | |
| Input.defaultProps = {
 | |
|     width: 'auto',
 | |
|     backgroundColor: colors.white,
 | |
|     fontColor: colors.darkestGrey,
 | |
|     placeholderColor: colors.darkGrey,
 | |
|     fontSize: '12px',
 | |
| };
 | |
| 
 | |
| Input.displayName = 'Input';
 |