mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-05 09:49:57 +08:00
d446bafc6b
* refactor: cssinjs for textarea * chore: code clean * refactor: better code style * test: fix lint * chore: code clean * test: fix rtl warning
390 lines
9.6 KiB
TypeScript
390 lines
9.6 KiB
TypeScript
// deps-lint-skip-all
|
|
import {
|
|
GenerateStyle,
|
|
resetComponent,
|
|
resetIcon,
|
|
UseComponentStyleResult,
|
|
useStyleRegister,
|
|
useToken,
|
|
} from '../../_util/theme';
|
|
import {
|
|
genActiveStyle,
|
|
genBasicInputStyle,
|
|
genDisabledStyle,
|
|
genHoverStyle,
|
|
genInputGroupStyle,
|
|
genPlaceholderStyle,
|
|
genStatusStyle,
|
|
initInputToken,
|
|
InputToken,
|
|
} from '../../input/style';
|
|
|
|
interface InputNumberToken extends InputToken {
|
|
inputNumberCls: string;
|
|
inputNumberHandlerActiveBgColor: string;
|
|
}
|
|
|
|
const genInputNumberStyles: GenerateStyle<InputNumberToken> = (token: InputNumberToken) => {
|
|
const {
|
|
inputNumberCls,
|
|
borderWidth,
|
|
borderStyle,
|
|
borderColor,
|
|
borderRadius,
|
|
fontSizeLG,
|
|
controlHeightLG,
|
|
controlHeightSM,
|
|
errorColor,
|
|
paddingXS,
|
|
textColorSecondary,
|
|
durationFast,
|
|
inputNumberHandlerActiveBgColor,
|
|
primaryColor,
|
|
marginXXS,
|
|
controlHeight,
|
|
inputPaddingHorizontal,
|
|
duration,
|
|
componentBackground,
|
|
durationMid,
|
|
textColorDisabled,
|
|
} = token;
|
|
|
|
return {
|
|
[inputNumberCls]: {
|
|
...resetComponent(token),
|
|
...genBasicInputStyle(token),
|
|
...genStatusStyle(token),
|
|
|
|
display: 'inline-block',
|
|
width: 90, // FIXME: magic number
|
|
margin: 0,
|
|
padding: 0,
|
|
border: `${borderWidth}px ${borderStyle} ${borderColor}`,
|
|
borderRadius,
|
|
|
|
'&-rtl': {
|
|
direction: 'rtl',
|
|
|
|
[`${inputNumberCls}-input`]: {
|
|
direction: 'rtl',
|
|
},
|
|
},
|
|
|
|
[`&:hover ${inputNumberCls}-handler-wrap, &-focused ${inputNumberCls}-handler-wrap`]: {
|
|
opacity: 1,
|
|
},
|
|
|
|
'&-lg': {
|
|
padding: 0,
|
|
fontSize: fontSizeLG,
|
|
|
|
[`input${inputNumberCls}-input`]: {
|
|
height: controlHeightLG - 2 * borderWidth,
|
|
},
|
|
},
|
|
|
|
'&-sm': {
|
|
padding: 0,
|
|
|
|
[`input${inputNumberCls}-input`]: {
|
|
height: controlHeightSM - 2 * borderWidth,
|
|
padding: `0 ${paddingXS - borderWidth}px`,
|
|
},
|
|
},
|
|
|
|
'&:hover': {
|
|
...genHoverStyle(token),
|
|
},
|
|
|
|
'&-focused': {
|
|
...genActiveStyle(token),
|
|
},
|
|
|
|
'&-disabled': {
|
|
...genDisabledStyle(token),
|
|
[`${inputNumberCls}-input`]: {
|
|
cursor: 'not-allowed',
|
|
},
|
|
[`${inputNumberCls}-handler-wrap`]: {
|
|
display: 'none',
|
|
},
|
|
},
|
|
|
|
'&-readonly': {
|
|
[`${inputNumberCls}-handler-wrap`]: {
|
|
display: 'none',
|
|
},
|
|
},
|
|
|
|
'&-borderless': {
|
|
boxShadow: 'none',
|
|
},
|
|
|
|
// ===================== Out Of Range =====================
|
|
'&-out-of-range': {
|
|
input: {
|
|
color: errorColor,
|
|
},
|
|
},
|
|
|
|
// Style for input-group: input with label, with button or dropdown...
|
|
'&-group': {
|
|
...resetComponent(token),
|
|
...genInputGroupStyle(token),
|
|
|
|
'&-wrapper': {
|
|
display: 'inline-block',
|
|
textAlign: 'start',
|
|
verticalAlign: 'top', // https://github.com/ant-design/ant-design/issues/6403
|
|
|
|
[`${inputNumberCls}-affix-wrapper`]: {
|
|
width: '100%',
|
|
},
|
|
},
|
|
},
|
|
|
|
[inputNumberCls]: {
|
|
'&-handler': {
|
|
position: 'relative',
|
|
display: 'block',
|
|
width: '100%',
|
|
height: '50%',
|
|
overflow: 'hidden',
|
|
color: textColorSecondary,
|
|
fontWeight: 'bold',
|
|
lineHeight: 0,
|
|
textAlign: 'center',
|
|
borderInlineStart: `${borderWidth}px ${borderStyle} ${borderColor}`,
|
|
transition: `all ${durationFast} linear`,
|
|
|
|
'&:active': {
|
|
background: inputNumberHandlerActiveBgColor,
|
|
},
|
|
|
|
'&:hover &-up-inner, &:hover &-down-inner': {
|
|
color: primaryColor,
|
|
},
|
|
},
|
|
|
|
'&-handler-up-inner, &-handler-down-inner': {
|
|
...resetIcon(),
|
|
|
|
position: 'absolute',
|
|
insetInlineEnd: marginXXS,
|
|
width: controlHeightSM / 2,
|
|
height: controlHeightSM / 2,
|
|
color: textColorSecondary,
|
|
lineHeight: controlHeightSM / 2,
|
|
transition: `all ${durationFast} linear`,
|
|
userSelect: 'none',
|
|
},
|
|
|
|
'&-input': {
|
|
width: '100%',
|
|
height: controlHeight - 2 * borderWidth,
|
|
padding: `0 ${inputPaddingHorizontal - borderWidth}px`,
|
|
textAlign: 'start',
|
|
backgroundColor: 'transparent',
|
|
border: 0,
|
|
borderRadius,
|
|
outline: 0,
|
|
transition: `all ${duration} linear`,
|
|
appearance: 'textfield', // FIXME: important
|
|
...genPlaceholderStyle(),
|
|
|
|
'&[type="number"]::-webkit-inner-spin-button, &[type="number"]::-webkit-outer-spin-button':
|
|
{
|
|
margin: 0,
|
|
/* stylelint-disable-next-line property-no-vendor-prefix */
|
|
webkitAppearance: 'none',
|
|
appearance: 'none',
|
|
},
|
|
},
|
|
|
|
'&-handler-wrap': {
|
|
position: 'absolute',
|
|
insetBlockStart: 0,
|
|
insetInlineEnd: 0,
|
|
width: 22, // FIXME: magic number
|
|
height: '100%',
|
|
background: componentBackground,
|
|
borderStartStartRadius: 0,
|
|
borderStartEndRadius: borderRadius,
|
|
borderEndEndRadius: borderRadius,
|
|
borderEndStartRadius: 0,
|
|
opacity: 0,
|
|
transition: `opacity ${durationMid} linear ${durationFast}`,
|
|
|
|
// Fix input number inside Menu makes icon too large
|
|
// We arise the selector priority by nest selector here
|
|
// https://github.com/ant-design/ant-design/issues/14367
|
|
[`${inputNumberCls}-handler`]: {
|
|
[`${inputNumberCls}-handler-up-inner,
|
|
${inputNumberCls}-handler-down-inner`]: {
|
|
display: 'flex',
|
|
alignItems: 'center',
|
|
justifyContent: 'center',
|
|
minWidth: 'auto',
|
|
marinInlineEnd: 0,
|
|
fontSize: 7, // FIXME: magic
|
|
},
|
|
},
|
|
|
|
[`${inputNumberCls}-borderless &`]: {
|
|
borderInlineStartWidth: 0,
|
|
},
|
|
|
|
[`&:hover ${inputNumberCls}-handler`]: {
|
|
height: '40%',
|
|
},
|
|
},
|
|
|
|
'&-handler-up': {
|
|
borderStartEndRadius: borderRadius,
|
|
cursor: 'pointer',
|
|
|
|
'&-inner': {
|
|
top: '50%',
|
|
marginTop: -5, // FIXME: magic
|
|
textAlign: 'center',
|
|
},
|
|
|
|
'&:hover': {
|
|
height: '60% !important',
|
|
},
|
|
},
|
|
|
|
'&-handler-down': {
|
|
top: 0,
|
|
borderBlockStart: `${borderWidth}px ${borderStyle} ${borderColor}`,
|
|
borderEndEndRadius: borderRadius,
|
|
cursor: 'pointer',
|
|
|
|
'&-inner': {
|
|
top: '50%',
|
|
textAlign: 'center',
|
|
transform: 'translateY(-50%)',
|
|
},
|
|
|
|
'&:hover': {
|
|
height: '60% !important',
|
|
},
|
|
|
|
[`${inputNumberCls}-borderless &`]: {
|
|
borderBlockStartWidth: 0,
|
|
},
|
|
},
|
|
'&-handler-up-disabled, &-handler-down-disabled': {
|
|
cursor: 'not-allowed',
|
|
},
|
|
|
|
[`&-handler-up-disabled:hover &-handler-up-inner,
|
|
&-handler-down-disabled:hover &-handler-down-inner`]: {
|
|
color: textColorDisabled,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
const genAffixWrapperStyles: GenerateStyle<InputNumberToken> = (token: InputNumberToken) => {
|
|
const { inputNumberCls, inputPaddingHorizontal, inputAffixMargin } = token;
|
|
|
|
return {
|
|
[`${inputNumberCls}-affix-wrapper`]: {
|
|
...genBasicInputStyle(token),
|
|
...genStatusStyle(token),
|
|
// or number handler will cover form status
|
|
position: 'relative',
|
|
display: 'inline-flex',
|
|
width: 90, // FIXME: magic
|
|
padding: 0,
|
|
paddingInlineStart: inputPaddingHorizontal,
|
|
|
|
'&:not(&-disabled):hover': {
|
|
...genHoverStyle(token),
|
|
zIndex: 1,
|
|
},
|
|
|
|
'&-focused, &:focus': {
|
|
zIndex: 1,
|
|
},
|
|
|
|
'&-disabled': {
|
|
[`${inputNumberCls}[disabled]`]: {
|
|
background: 'transparent',
|
|
},
|
|
},
|
|
|
|
[`> div${inputNumberCls}`]: {
|
|
width: '100%',
|
|
border: 'none',
|
|
outline: 'none',
|
|
|
|
[`&${inputNumberCls}-focused`]: {
|
|
boxShadow: 'none !important',
|
|
},
|
|
},
|
|
|
|
[`input${inputNumberCls}-input`]: {
|
|
padding: 0,
|
|
},
|
|
|
|
'&::before': {
|
|
width: 0,
|
|
visibility: 'hidden',
|
|
content: '"\\a0"',
|
|
},
|
|
|
|
[`${inputNumberCls}-handler-wrap`]: {
|
|
zIndex: 2,
|
|
},
|
|
|
|
[inputNumberCls]: {
|
|
'&-prefix, &-suffix': {
|
|
display: 'flex',
|
|
flex: 'none',
|
|
alignItems: 'center',
|
|
pointerEvents: 'none',
|
|
},
|
|
|
|
'&-prefix': {
|
|
marginInlineEnd: inputAffixMargin,
|
|
},
|
|
|
|
'&-suffix': {
|
|
position: 'absolute',
|
|
insetBlockStart: 0,
|
|
insetInlineEnd: 0,
|
|
zIndex: 1,
|
|
height: '100%',
|
|
marginInlineEnd: inputPaddingHorizontal,
|
|
marginInlineStart: inputAffixMargin,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
// ============================== Export ==============================
|
|
export default function useStyle(
|
|
prefixCls: string,
|
|
iconPrefixCls: string,
|
|
): UseComponentStyleResult {
|
|
const [theme, token, hashId] = useToken();
|
|
|
|
const inputNumberToken: InputNumberToken = {
|
|
...initInputToken(token, prefixCls, iconPrefixCls),
|
|
inputNumberCls: `.${prefixCls}`,
|
|
inputNumberHandlerActiveBgColor: '#f4f4f4', // FIXME: magic number
|
|
};
|
|
|
|
return [
|
|
useStyleRegister({ theme, token, hashId, path: [prefixCls] }, () => [
|
|
genInputNumberStyles(inputNumberToken),
|
|
genAffixWrapperStyles(inputNumberToken),
|
|
]),
|
|
hashId,
|
|
];
|
|
}
|