ohmyform-ui/components/styled/number.input.tsx
2020-05-31 23:18:16 +02:00

54 lines
1.3 KiB
TypeScript

import {InputNumber} from 'antd'
import {InputNumberProps} from 'antd/lib/input-number'
import React from 'react'
import styled from 'styled-components'
import {FormDesignFragment} from '../../graphql/fragment/form.fragment'
import {transparentize} from './color.change'
interface Props extends InputNumberProps {
design: FormDesignFragment
}
const Field = styled(InputNumber)`
color: ${props => props.design.colors.answerColor};
border-color: ${props => props.design.colors.answerColor};
background: none !important;
border-right: none;
border-top: none;
border-left: none;
border-radius: 0;
width: 100%;
:focus {
outline: ${props => props.design.colors.answerColor} auto 5px
}
:hover,
:active {
border-color: ${props => props.design.colors.answerColor};
}
&.ant-input-number {
box-shadow: none
}
input {
background: none !important;
color: ${props => props.design.colors.answerColor};
::placeholder {
color: ${props => transparentize(props.design.colors.answerColor, 60)}
}
}
.anticon {
color: ${props => props.design.colors.answerColor};
}
`
export const StyledNumberInput: React.FC<Props> = ({children, ...props}) => {
return (
<Field {...props}>{children}</Field>
)
}