| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 | 
							- import React, { useEffect, useMemo, useRef, useState } from 'react'
 
- import { createPortal } from 'react-dom'
 
- import { useTranslation } from 'react-i18next'
 
- import {
 
-   RiExternalLinkLine,
 
- } from '@remixicon/react'
 
- import Button from '@/app/components/base/button'
 
- import { getLocaleOnClient } from '@/i18n'
 
- export type IConfirm = {
 
-   className?: string
 
-   isShow: boolean
 
-   title: string
 
-   content?: React.ReactNode
 
-   onConfirm: () => void
 
-   onCancel: () => void
 
-   maskClosable?: boolean
 
-   email?: string
 
-   showLink?: boolean
 
- }
 
- function Confirm({
 
-   isShow,
 
-   title,
 
-   content,
 
-   onConfirm,
 
-   onCancel,
 
-   maskClosable = true,
 
-   showLink,
 
-   email,
 
- }: IConfirm) {
 
-   const { t } = useTranslation()
 
-   const locale = getLocaleOnClient()
 
-   const dialogRef = useRef<HTMLDivElement>(null)
 
-   const [isVisible, setIsVisible] = useState(isShow)
 
-   const docLink = useMemo(() => {
 
-     if (locale === 'zh-Hans')
 
-       return 'https://docs.dify.ai/zh-hans/getting-started/dify-for-education'
 
-     if (locale === 'ja-JP')
 
-       return 'https://docs.dify.ai/ja-jp/getting-started/dify-for-education'
 
-     return 'https://docs.dify.ai/getting-started/dify-for-education'
 
-   }, [locale])
 
-   const handleClick = () => {
 
-     window.open(docLink, '_blank', 'noopener,noreferrer')
 
-   }
 
-   useEffect(() => {
 
-     const handleKeyDown = (event: KeyboardEvent) => {
 
-       if (event.key === 'Escape')
 
-         onCancel()
 
-     }
 
-     document.addEventListener('keydown', handleKeyDown)
 
-     return () => {
 
-       document.removeEventListener('keydown', handleKeyDown)
 
-     }
 
-   }, [onCancel])
 
-   const handleClickOutside = (event: MouseEvent) => {
 
-     if (maskClosable && dialogRef.current && !dialogRef.current.contains(event.target as Node))
 
-       onCancel()
 
-   }
 
-   useEffect(() => {
 
-     document.addEventListener('mousedown', handleClickOutside)
 
-     return () => {
 
-       document.removeEventListener('mousedown', handleClickOutside)
 
-     }
 
-   }, [maskClosable])
 
-   useEffect(() => {
 
-     if (isShow) {
 
-       setIsVisible(true)
 
-     }
 
-     else {
 
-       const timer = setTimeout(() => setIsVisible(false), 200)
 
-       return () => clearTimeout(timer)
 
-     }
 
-   }, [isShow])
 
-   if (!isVisible)
 
-     return null
 
-   return createPortal(
 
-     <div className={'fixed inset-0 z-[10000000] flex items-center justify-center bg-background-overlay'}
 
-       onClick={(e) => {
 
-         e.preventDefault()
 
-         e.stopPropagation()
 
-       }}
 
-     >
 
-       <div ref={dialogRef} className={'relative w-full max-w-[481px] overflow-hidden'}>
 
-         <div className='shadows-shadow-lg flex max-w-full flex-col items-start rounded-2xl border-[0.5px] border-solid border-components-panel-border bg-components-panel-bg'>
 
-           <div className='flex flex-col items-start gap-2 self-stretch pb-4 pl-6 pr-6 pt-6'>
 
-             <div className='title-2xl-semi-bold text-text-primary'>{title}</div>
 
-             <div className='system-md-regular w-full text-text-tertiary'>{content}</div>
 
-           </div>
 
-           {email && (
 
-             <div className='w-full space-y-1 px-6 py-3'>
 
-               <div className='system-sm-semibold py-1 text-text-secondary'>{t('education.emailLabel')}</div>
 
-               <div className='system-sm-regular rounded-lg bg-components-input-bg-disabled px-3 py-2 text-components-input-text-filled-disabled'>{email}</div>
 
-             </div>
 
-           )}
 
-           <div className='flex items-center justify-between gap-2 self-stretch p-6'>
 
-             <div className='flex items-center gap-1'>
 
-               {showLink && (
 
-                 <>
 
-                   <a onClick={handleClick} href={docLink} target='_blank' className='system-xs-regular cursor-pointer text-text-accent'>{t('education.learn')}</a>
 
-                   <RiExternalLinkLine className='h-3 w-3 text-text-accent' />
 
-                 </>
 
-               )}
 
-             </div>
 
-             <Button variant='primary' className='!w-20' onClick={onConfirm}>{t('common.operation.ok')}</Button>
 
-           </div>
 
-         </div>
 
-       </div>
 
-     </div>, document.body,
 
-   )
 
- }
 
- export default React.memo(Confirm)
 
 
  |