ant-design-vue/components/qrcode/index.tsx

106 lines
3.3 KiB
Vue
Raw Normal View History

2023-03-03 06:56:23 +00:00
import { defineComponent, computed, ref } from 'vue';
2023-03-03 08:58:47 +00:00
import type { CSSProperties, ExtractPropTypes } from 'vue';
import useConfigInject from '../config-provider/hooks/useConfigInject';
import useStyle from './style';
import { useLocaleReceiver } from '../locale/LocaleReceiver';
import { withInstall } from '../_util/type';
import Spin from '../spin';
import Button from '../button';
import { ReloadOutlined } from '@ant-design/icons-vue';
import { useToken } from '../theme/internal';
2023-03-03 06:56:23 +00:00
import { QRCodeCanvas } from './QRCodeCanvas';
import warning from '../_util/warning';
import { qrcodeProps } from './interface';
2023-03-03 08:58:47 +00:00
export type QRCodeProps = Partial<ExtractPropTypes<ReturnType<typeof qrcodeProps>>>;
const QRCode = defineComponent({
name: 'AQrcode',
2023-03-03 06:56:23 +00:00
inheritAttrs: false,
props: qrcodeProps(),
emits: ['refresh'],
2023-03-03 06:56:23 +00:00
setup(props, { emit, attrs, expose }) {
if (process.env.NODE_ENV !== 'production') {
warning(
!(props.icon && props.errorLevel === 'L'),
'QRCode',
'ErrorLevel `L` is not recommended to be used with `icon`, for scanning result would be affected by low level.',
);
}
const [locale] = useLocaleReceiver('QRCode');
const { prefixCls } = useConfigInject('qrcode', props);
const [wrapSSR, hashId] = useStyle(prefixCls);
const [, token] = useToken();
2023-03-03 06:56:23 +00:00
const qrCodeCanvas = ref();
expose({
toDataURL: (type?: string, quality?: any) => {
return qrCodeCanvas.value?.toDataURL(type, quality);
},
});
const qrCodeProps = computed(() => {
const {
value,
icon = '',
size = 160,
iconSize = 40,
color = '#000',
errorLevel = 'M',
} = props;
const imageSettings: QRCodeProps['imageSettings'] = {
src: icon,
x: undefined,
y: undefined,
height: iconSize,
width: iconSize,
excavate: true,
};
return {
value,
size: size - (token.value.paddingSM + token.value.lineWidth) * 2,
level: errorLevel,
bgColor: 'transparent',
fgColor: color,
imageSettings: icon ? imageSettings : undefined,
};
});
return () => {
2023-03-03 06:56:23 +00:00
const pre = prefixCls.value;
return wrapSSR(
<div
2023-03-03 06:56:23 +00:00
{...attrs}
style={[
attrs.style as CSSProperties,
{ width: props.size + 'px', height: props.size + 'px' },
]}
class={[
hashId.value,
pre,
{
[`${prefixCls}-borderless`]: !props.bordered,
},
]}
>
{props.status !== 'active' && (
2023-03-03 06:56:23 +00:00
<div class={`${pre}-mask`}>
{props.status === 'loading' && <Spin />}
{props.status === 'expired' && (
<>
2023-03-03 06:56:23 +00:00
<p class={`${pre}-expired`}>{locale.value.expired}</p>
<Button
type="link"
onClick={e => emit('refresh', e)}
v-slots={{ icon: () => <ReloadOutlined /> }}
>
{locale.value.refresh}
</Button>
</>
)}
</div>
)}
2023-03-03 06:56:23 +00:00
<QRCodeCanvas ref={qrCodeCanvas} {...qrCodeProps.value} />
</div>,
);
};
},
});
export default withInstall(QRCode);