2023-11-14 10:34:01 +08:00
|
|
|
import { unit } from '@ant-design/cssinjs';
|
|
|
|
|
2023-07-17 23:43:32 +08:00
|
|
|
import { resetComponent } from '../../style';
|
2023-11-14 10:34:01 +08:00
|
|
|
import type { FullToken, GenerateStyle, GetDefaultToken } from '../../theme/internal';
|
2023-07-17 23:43:32 +08:00
|
|
|
import { genComponentStyleHook, mergeToken } from '../../theme/internal';
|
|
|
|
|
|
|
|
export interface ComponentToken {}
|
|
|
|
|
|
|
|
interface QRCodeToken extends FullToken<'QRCode'> {
|
|
|
|
QRCodeExpiredTextColor: string;
|
|
|
|
QRCodeMaskBackgroundColor: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const genQRCodeStyle: GenerateStyle<QRCodeToken> = (token) => {
|
2023-11-14 10:34:01 +08:00
|
|
|
const { componentCls, lineWidth, lineType, colorSplit } = token;
|
2023-07-17 23:43:32 +08:00
|
|
|
return {
|
|
|
|
[componentCls]: {
|
|
|
|
...resetComponent(token),
|
|
|
|
display: 'flex',
|
|
|
|
justifyContent: 'center',
|
|
|
|
alignItems: 'center',
|
|
|
|
padding: token.paddingSM,
|
|
|
|
backgroundColor: token.colorWhite,
|
|
|
|
borderRadius: token.borderRadiusLG,
|
2023-11-14 10:34:01 +08:00
|
|
|
border: `${unit(lineWidth)} ${lineType} ${colorSplit}`,
|
2023-07-17 23:43:32 +08:00
|
|
|
position: 'relative',
|
|
|
|
overflow: 'hidden',
|
2023-11-13 18:35:23 +08:00
|
|
|
|
2023-07-17 23:43:32 +08:00
|
|
|
[`& > ${componentCls}-mask`]: {
|
|
|
|
position: 'absolute',
|
|
|
|
insetBlockStart: 0,
|
|
|
|
insetInlineStart: 0,
|
|
|
|
zIndex: 10,
|
|
|
|
display: 'flex',
|
|
|
|
flexDirection: 'column',
|
|
|
|
justifyContent: 'center',
|
|
|
|
alignItems: 'center',
|
|
|
|
width: '100%',
|
|
|
|
height: '100%',
|
|
|
|
color: token.colorText,
|
|
|
|
lineHeight: token.lineHeight,
|
|
|
|
background: token.QRCodeMaskBackgroundColor,
|
|
|
|
textAlign: 'center',
|
|
|
|
[`& > ${componentCls}-expired`]: {
|
|
|
|
color: token.QRCodeExpiredTextColor,
|
|
|
|
},
|
|
|
|
},
|
2023-11-13 18:35:23 +08:00
|
|
|
|
|
|
|
'> canvas': {
|
|
|
|
alignSelf: 'stretch',
|
|
|
|
flex: 'auto',
|
|
|
|
minWidth: 0,
|
|
|
|
},
|
|
|
|
|
2023-07-17 23:43:32 +08:00
|
|
|
'&-icon': {
|
|
|
|
marginBlockEnd: token.marginXS,
|
|
|
|
fontSize: token.controlHeight,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[`${componentCls}-borderless`]: {
|
|
|
|
borderColor: 'transparent',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-11-14 10:34:01 +08:00
|
|
|
export const prepareComponentToken: GetDefaultToken<'QRCode'> = () => ({});
|
|
|
|
|
|
|
|
export default genComponentStyleHook<'QRCode'>(
|
|
|
|
'QRCode',
|
|
|
|
(token) => {
|
|
|
|
const mergedToken = mergeToken<QRCodeToken>(token, {
|
2023-07-17 23:43:32 +08:00
|
|
|
QRCodeExpiredTextColor: 'rgba(0, 0, 0, 0.88)',
|
|
|
|
QRCodeMaskBackgroundColor: 'rgba(255, 255, 255, 0.96)',
|
2023-11-14 10:34:01 +08:00
|
|
|
});
|
|
|
|
return genQRCodeStyle(mergedToken);
|
|
|
|
},
|
|
|
|
prepareComponentToken,
|
2023-07-17 23:43:32 +08:00
|
|
|
);
|