52 lines
1.6 KiB
JavaScript
52 lines
1.6 KiB
JavaScript
|
import { resetComponent } from '../../style';
|
||
|
import { genComponentStyleHook, mergeToken } from '../../theme/internal';
|
||
|
const genQRCodeStyle = token => {
|
||
|
const {
|
||
|
componentCls
|
||
|
} = token;
|
||
|
return {
|
||
|
[componentCls]: Object.assign(Object.assign({}, resetComponent(token)), {
|
||
|
display: 'flex',
|
||
|
justifyContent: 'center',
|
||
|
alignItems: 'center',
|
||
|
padding: token.paddingSM,
|
||
|
backgroundColor: token.colorWhite,
|
||
|
borderRadius: token.borderRadiusLG,
|
||
|
border: `${token.lineWidth}px ${token.lineType} ${token.colorSplit}`,
|
||
|
position: 'relative',
|
||
|
width: '100%',
|
||
|
height: '100%',
|
||
|
overflow: 'hidden',
|
||
|
[`& > ${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
|
||
|
}
|
||
|
},
|
||
|
'&-icon': {
|
||
|
marginBlockEnd: token.marginXS,
|
||
|
fontSize: token.controlHeight
|
||
|
}
|
||
|
}),
|
||
|
[`${componentCls}-borderless`]: {
|
||
|
borderColor: 'transparent'
|
||
|
}
|
||
|
};
|
||
|
};
|
||
|
export default genComponentStyleHook('QRCode', token => genQRCodeStyle(mergeToken(token, {
|
||
|
QRCodeExpiredTextColor: 'rgba(0, 0, 0, 0.88)',
|
||
|
QRCodeMaskBackgroundColor: 'rgba(255, 255, 255, 0.96)'
|
||
|
})));
|