| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | 
							- import { CheckCircleIcon } from '@heroicons/react/24/solid'
 
- import { QuestionMarkCircleIcon, XMarkIcon } from '@heroicons/react/24/outline'
 
- import { useTranslation } from 'react-i18next'
 
- import { useMemo } from 'react'
 
- import InvitationLink from './invitation-link'
 
- import s from './index.module.css'
 
- import Modal from '@/app/components/base/modal'
 
- import Button from '@/app/components/base/button'
 
- import { IS_CE_EDITION } from '@/config'
 
- import type { InvitationResult } from '@/models/common'
 
- import Tooltip from '@/app/components/base/tooltip'
 
- export type SuccessInvationResult = Extract<InvitationResult, { status: 'success' }>
 
- export type FailedInvationResult = Extract<InvitationResult, { status: 'failed' }>
 
- type IInvitedModalProps = {
 
-   invitationResults: InvitationResult[]
 
-   onCancel: () => void
 
- }
 
- const InvitedModal = ({
 
-   invitationResults,
 
-   onCancel,
 
- }: IInvitedModalProps) => {
 
-   const { t } = useTranslation()
 
-   const successInvationResults = useMemo<SuccessInvationResult[]>(() => invitationResults?.filter(item => item.status === 'success') as SuccessInvationResult[], [invitationResults])
 
-   const failedInvationResults = useMemo<FailedInvationResult[]>(() => invitationResults?.filter(item => item.status !== 'success') as FailedInvationResult[], [invitationResults])
 
-   return (
 
-     <div className={s.wrap}>
 
-       <Modal isShow onClose={() => {}} className={s.modal}>
 
-         <div className='flex justify-between mb-3'>
 
-           <div className='
 
-             w-12 h-12 flex items-center justify-center rounded-xl
 
-             bg-white border-[0.5px] border-gray-100
 
-             shadow-xl
 
-           '>
 
-             <CheckCircleIcon className='w-[22px] h-[22px] text-[#039855]' />
 
-           </div>
 
-           <XMarkIcon className='w-4 h-4 cursor-pointer' onClick={onCancel} />
 
-         </div>
 
-         <div className='mb-1 text-xl font-semibold text-gray-900'>{t('common.members.invitationSent')}</div>
 
-         {!IS_CE_EDITION && (
 
-           <div className='mb-10 text-sm text-gray-500'>{t('common.members.invitationSentTip')}</div>
 
-         )}
 
-         {IS_CE_EDITION && (
 
-           <>
 
-             <div className='mb-5 text-sm text-gray-500'>{t('common.members.invitationSentTip')}</div>
 
-             <div className='flex flex-col gap-2 mb-9'>
 
-               {
 
-                 !!successInvationResults.length
 
-                   && <>
 
-                     <div className='py-2 text-sm font-Medium text-gray-900'>{t('common.members.invitationLink')}</div>
 
-                     {successInvationResults.map(item =>
 
-                       <InvitationLink key={item.email} value={item} />)}
 
-                   </>
 
-               }
 
-               {
 
-                 !!failedInvationResults.length
 
-                   && <>
 
-                     <div className='py-2 text-sm font-Medium text-gray-900'>{t('common.members.failedinvitationEmails')}</div>
 
-                     <div className='flex flex-wrap justify-between gap-y-1'>
 
-                       {
 
-                         failedInvationResults.map(item =>
 
-                           <div key={item.email} className='flex justify-center border border-red-300 rounded-md px-1 bg-orange-50'>
 
-                             <Tooltip
 
-                               selector={`invitation-tag-${item.email}`}
 
-                               htmlContent={item.message}
 
-                             >
 
-                               <div className='flex justify-center items-center text-sm gap-1'>
 
-                                 {item.email}
 
-                                 <QuestionMarkCircleIcon className='w-4 h-4 text-red-300' />
 
-                               </div>
 
-                             </Tooltip>
 
-                           </div>,
 
-                         )
 
-                       }
 
-                     </div>
 
-                   </>
 
-               }
 
-             </div>
 
-           </>
 
-         )}
 
-         <div className='flex justify-end'>
 
-           <Button
 
-             className='w-[96px] text-sm font-medium'
 
-             onClick={onCancel}
 
-             type='primary'
 
-           >
 
-             {t('common.members.ok')}
 
-           </Button>
 
-         </div>
 
-       </Modal>
 
-     </div>
 
-   )
 
- }
 
- export default InvitedModal
 
 
  |