2022-03-10 10:47:33 +08:00
|
|
|
// deps-lint-skip-all
|
2022-03-11 14:29:29 +08:00
|
|
|
import { CSSObject } from '@ant-design/cssinjs';
|
2022-03-10 10:47:33 +08:00
|
|
|
import {
|
|
|
|
DerivativeToken,
|
|
|
|
resetComponent,
|
|
|
|
UseComponentStyleResult,
|
|
|
|
useStyleRegister,
|
|
|
|
useToken,
|
2022-03-11 14:29:29 +08:00
|
|
|
GenerateStyle,
|
2022-03-10 10:47:33 +08:00
|
|
|
} from '../../_util/theme';
|
2019-03-11 11:00:25 +08:00
|
|
|
|
2022-03-10 10:47:33 +08:00
|
|
|
interface RateToken extends DerivativeToken {
|
|
|
|
rateStarColor: string;
|
|
|
|
rateStarSize: number;
|
|
|
|
rateStarHoverScale: CSSObject['transform'];
|
|
|
|
rateCls: string;
|
|
|
|
iconPrefixCls: string;
|
|
|
|
}
|
|
|
|
|
2022-03-11 14:29:29 +08:00
|
|
|
const genRateStarStyle: GenerateStyle<RateToken, CSSObject> = token => {
|
2022-03-10 10:47:33 +08:00
|
|
|
const { rateCls } = token;
|
|
|
|
|
|
|
|
return {
|
|
|
|
[`${rateCls}-star`]: {
|
|
|
|
position: 'relative',
|
|
|
|
display: 'inline-block',
|
|
|
|
color: 'inherit',
|
|
|
|
cursor: 'pointer',
|
|
|
|
|
|
|
|
'&:not(:last-child)': {
|
|
|
|
marginInlineEnd: token.marginXS,
|
|
|
|
},
|
|
|
|
|
|
|
|
'> div': {
|
|
|
|
transition: `all ${token.duration}, outline 0s`,
|
|
|
|
|
|
|
|
'&:hover': {
|
|
|
|
transform: token.rateStarHoverScale,
|
|
|
|
},
|
|
|
|
|
|
|
|
'&:focus': {
|
|
|
|
outline: 0,
|
|
|
|
},
|
|
|
|
|
|
|
|
'&:focus-visible': {
|
|
|
|
outline: `1px dashed ${token.borderColorSplit}`,
|
|
|
|
transform: token.rateStarHoverScale,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
'&-first, &-second': {
|
|
|
|
color: token.borderColorSplit,
|
|
|
|
transition: `all ${token.duration}`,
|
|
|
|
userSelect: 'none',
|
|
|
|
|
|
|
|
[token.iconPrefixCls]: {
|
|
|
|
verticalAlign: 'middle',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
'&-first': {
|
|
|
|
position: 'absolute',
|
|
|
|
top: 0,
|
|
|
|
insetInlineStart: 0,
|
|
|
|
width: '50%',
|
|
|
|
height: '100%',
|
|
|
|
overflow: 'hidden',
|
|
|
|
opacity: 0,
|
|
|
|
},
|
|
|
|
|
|
|
|
[`&-half ${rateCls}-star-first, &-half ${rateCls}-star-second`]: {
|
|
|
|
opacity: 1,
|
|
|
|
},
|
|
|
|
|
|
|
|
[`&-half ${rateCls}-star-first, &-full ${rateCls}-star-second`]: {
|
|
|
|
color: 'inherit',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const genRateRtlStyle = (token: RateToken): CSSObject => ({
|
|
|
|
[`&-rtl${token.rateCls}`]: {
|
|
|
|
direction: 'rtl',
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2022-03-11 14:29:29 +08:00
|
|
|
const genRateStyle: GenerateStyle<RateToken> = token => {
|
2022-03-10 10:47:33 +08:00
|
|
|
const { rateCls } = token;
|
|
|
|
|
|
|
|
return {
|
|
|
|
[rateCls]: {
|
|
|
|
...resetComponent(token),
|
|
|
|
|
|
|
|
display: 'inline-block',
|
|
|
|
margin: 0,
|
|
|
|
padding: 0,
|
|
|
|
color: token.rateStarColor,
|
|
|
|
fontSize: token.rateStarSize,
|
|
|
|
lineHeight: 'unset',
|
|
|
|
listStyle: 'none',
|
|
|
|
outline: 'none',
|
|
|
|
|
|
|
|
// disable styles
|
|
|
|
[`&-disabled${rateCls} ${rateCls}-star`]: {
|
|
|
|
cursor: 'default',
|
|
|
|
|
|
|
|
'&:hover': {
|
|
|
|
transform: 'scale(1)',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
// star styles
|
|
|
|
...genRateStarStyle(token),
|
|
|
|
|
|
|
|
// text styles
|
|
|
|
[`+ ${rateCls}-text`]: {
|
|
|
|
display: 'inline-block',
|
|
|
|
marginInlineStart: token.marginXS,
|
|
|
|
fontSize: token.fontSize,
|
|
|
|
},
|
|
|
|
|
|
|
|
// rtl styles
|
|
|
|
...genRateRtlStyle(token),
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
// ============================== Export ==============================
|
|
|
|
export default function useStyle(
|
|
|
|
prefixCls: string,
|
|
|
|
iconPrefixCls: string,
|
|
|
|
): UseComponentStyleResult {
|
|
|
|
const [theme, token, hashId] = useToken();
|
|
|
|
|
|
|
|
const rateToken: RateToken = {
|
|
|
|
...token,
|
|
|
|
// FIXME: missing token
|
|
|
|
rateStarColor: '#fadb14', // @yellow-6
|
|
|
|
rateStarSize: 20, // fixed-value
|
|
|
|
rateStarHoverScale: 'scale(1.1)', // fixed-value
|
|
|
|
rateCls: `.${prefixCls}`,
|
|
|
|
iconPrefixCls: `.${iconPrefixCls}`,
|
|
|
|
};
|
|
|
|
|
|
|
|
return [
|
|
|
|
useStyleRegister({ theme, token, hashId, path: [prefixCls] }, () => [genRateStyle(rateToken)]),
|
|
|
|
hashId,
|
|
|
|
];
|
|
|
|
}
|