wwf
2025-05-20 938c3e5a587ce950a94964ea509b9e7f8834dfae
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
'use client'
import React, { useEffect, useRef, useState } from 'react'
import { useTranslation } from 'react-i18next'
import {
  RiQrCodeLine,
} from '@remixicon/react'
import { QRCodeCanvas as QRCode } from 'qrcode.react'
import ActionButton from '@/app/components/base/action-button'
import Tooltip from '@/app/components/base/tooltip'
 
type Props = {
  content: string
}
 
const prefixEmbedded = 'appOverview.overview.appInfo.qrcode.title'
 
const ShareQRCode = ({ content }: Props) => {
  const { t } = useTranslation()
  const [isShow, setIsShow] = useState<boolean>(false)
  const qrCodeRef = useRef<HTMLDivElement>(null)
 
  const toggleQRCode = (event: React.MouseEvent) => {
    event.stopPropagation()
    setIsShow(prev => !prev)
  }
 
  useEffect(() => {
    const handleClickOutside = (event: MouseEvent) => {
      if (qrCodeRef.current && !qrCodeRef.current.contains(event.target as Node))
        setIsShow(false)
    }
 
    if (isShow)
      document.addEventListener('click', handleClickOutside)
 
    return () => {
      document.removeEventListener('click', handleClickOutside)
    }
  }, [isShow])
 
  const downloadQR = () => {
    const canvas = document.getElementsByTagName('canvas')[0]
    const link = document.createElement('a')
    link.download = 'qrcode.png'
    link.href = canvas.toDataURL()
    link.click()
  }
 
  const handlePanelClick = (event: React.MouseEvent) => {
    event.stopPropagation()
  }
 
  return (
    <Tooltip
      popupContent={t(`${prefixEmbedded}`) || ''}
    >
      <div className='relative h-6 w-6' onClick={toggleQRCode}>
        <ActionButton>
          <RiQrCodeLine className='h-4 w-4' />
        </ActionButton>
        {isShow && (
          <div
            ref={qrCodeRef}
            className='absolute -right-8 top-8 z-10 flex w-[232px] flex-col items-center rounded-lg bg-components-panel-bg p-4 shadow-xs'
            onClick={handlePanelClick}
          >
            <QRCode size={160} value={content} className='mb-2' />
            <div className='system-xs-regular flex items-center'>
              <div className='text-text-tertiary'>{t('appOverview.overview.appInfo.qrcode.scan')}</div>
              <div className='text-text-tertiary'>·</div>
              <div className='cursor-pointer text-text-accent-secondary' onClick={downloadQR}>{t('appOverview.overview.appInfo.qrcode.download')}</div>
            </div>
          </div>
        )}
      </div>
    </Tooltip>
  )
}
 
export default ShareQRCode