| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  | 'use client' | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  | import React, { useEffect, useRef, useState } from 'react' | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   RiQrCodeLine, | 
					
						
							|  |  |  | } from '@remixicon/react' | 
					
						
							|  |  |  | import { QRCodeCanvas as QRCode } from 'qrcode.react' | 
					
						
							|  |  |  | import ActionButton from '@/app/components/base/action-button' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | type Props = { | 
					
						
							|  |  |  |   content: string | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const prefixEmbedded = 'appOverview.overview.appInfo.qrcode.title' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  | const ShareQRCode = ({ content }: Props) => { | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |   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]) | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const downloadQR = () => { | 
					
						
							|  |  |  |     const canvas = document.getElementsByTagName('canvas')[0] | 
					
						
							|  |  |  |     const link = document.createElement('a') | 
					
						
							|  |  |  |     link.download = 'qrcode.png' | 
					
						
							|  |  |  |     link.href = canvas.toDataURL() | 
					
						
							|  |  |  |     link.click() | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |   const handlePanelClick = (event: React.MouseEvent) => { | 
					
						
							|  |  |  |     event.stopPropagation() | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |       popupContent={t(`${prefixEmbedded}`) || ''} | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  |     > | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='relative h-6 w-6' onClick={toggleQRCode}> | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  |         <ActionButton> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |           <RiQrCodeLine className='h-4 w-4' /> | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  |         </ActionButton> | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |         {isShow && ( | 
					
						
							|  |  |  |           <div | 
					
						
							|  |  |  |             ref={qrCodeRef} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |             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' | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |             onClick={handlePanelClick} | 
					
						
							|  |  |  |           > | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  |             <QRCode size={160} value={content} className='mb-2' /> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |             <div className='system-xs-regular flex items-center'> | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  |               <div className='text-text-tertiary'>{t('appOverview.overview.appInfo.qrcode.scan')}</div> | 
					
						
							|  |  |  |               <div className='text-text-tertiary'>·</div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               <div className='cursor-pointer text-text-accent-secondary' onClick={downloadQR}>{t('appOverview.overview.appInfo.qrcode.download')}</div> | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-07-16 02:06:49 -05:00
										 |  |  |         )} | 
					
						
							| 
									
										
										
										
											2023-10-07 20:34:49 -05:00
										 |  |  |       </div> | 
					
						
							|  |  |  |     </Tooltip> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default ShareQRCode |