import React from 'react'; import { QRCodeCanvas, QRCodeSVG } from '@rc-component/qrcode'; import omit from '@rc-component/util/lib/omit'; import pickAttrs from '@rc-component/util/lib/pickAttrs'; import cls from 'classnames'; import useMergeSemantic from '../_util/hooks/useMergeSemantic'; import { devUseWarning } from '../_util/warning'; import { useComponentConfig } from '../config-provider/context'; import { useLocale } from '../locale'; import { useToken } from '../theme/internal'; import type { QRCodeProps, QRProps } from './interface'; import QRcodeStatus from './QrcodeStatus'; import useStyle from './style/index'; export type { QRCodeProps, QRProps }; const QRCode: React.FC = (props) => { const [, token] = useToken(); const { value, type = 'canvas', icon = '', size = 160, iconSize, color = token.colorText, errorLevel = 'M', status = 'active', bordered = true, onRefresh, style, className, rootClassName, prefixCls: customizePrefixCls, bgColor = 'transparent', statusRender, classNames: qrcodeClassNames, styles, ...rest } = props; const { getPrefixCls, className: contextClassName, style: contextStyle, classNames: contextClassNames, styles: contextStyles, } = useComponentConfig('qrcode'); const [mergedClassNames, mergedStyles] = useMergeSemantic( [contextClassNames, qrcodeClassNames], [contextStyles, styles], ); const prefixCls = getPrefixCls('qrcode', customizePrefixCls); const [hashId, cssVarCls] = useStyle(prefixCls); const imageSettings: QRProps['imageSettings'] = { src: icon, x: undefined, y: undefined, height: typeof iconSize === 'number' ? iconSize : (iconSize?.height ?? 40), width: typeof iconSize === 'number' ? iconSize : (iconSize?.width ?? 40), excavate: true, crossOrigin: 'anonymous', }; const a11yProps = pickAttrs(rest, true); const restProps = omit, keyof React.AriaAttributes>( rest, Object.keys(a11yProps) as (keyof React.AriaAttributes)[], ); const qrCodeProps = { value, size, level: errorLevel, bgColor, fgColor: color, style: { width: style?.width, height: style?.height }, imageSettings: icon ? imageSettings : undefined, ...a11yProps, }; const [locale] = useLocale('QRCode'); if (process.env.NODE_ENV !== 'production') { const warning = devUseWarning('QRCode'); warning(!!value, 'usage', 'need to receive `value` props'); warning( !(icon && errorLevel === 'L'), 'usage', 'ErrorLevel `L` is not recommended to be used with `icon`, for scanning result would be affected by low level.', ); } if (!value) { return null; } const rootClassNames = cls( prefixCls, className, rootClassName, hashId, cssVarCls, contextClassName, mergedClassNames.root, { [`${prefixCls}-borderless`]: !bordered, }, ); const rootStyle: React.CSSProperties = { backgroundColor: bgColor, ...mergedStyles.root, ...contextStyle, ...style, width: style?.width ?? size, height: style?.height ?? size, }; return (
{status !== 'active' && (
)} {type === 'canvas' ? : }
); }; if (process.env.NODE_ENV !== 'production') { QRCode.displayName = 'QRCode'; } export default QRCode;