index.tsx 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { CheckCircleIcon } from '@heroicons/react/24/solid'
  2. import { XMarkIcon } from '@heroicons/react/24/outline'
  3. import { useTranslation } from 'react-i18next'
  4. import InvitationLink from './invitation-link'
  5. import s from './index.module.css'
  6. import Modal from '@/app/components/base/modal'
  7. import Button from '@/app/components/base/button'
  8. import { IS_CE_EDITION } from '@/config'
  9. type IInvitedModalProps = {
  10. invitationLink: string
  11. onCancel: () => void
  12. }
  13. const InvitedModal = ({
  14. invitationLink,
  15. onCancel,
  16. }: IInvitedModalProps) => {
  17. const { t } = useTranslation()
  18. return (
  19. <div className={s.wrap}>
  20. <Modal isShow onClose={() => {}} className={s.modal}>
  21. <div className='flex justify-between mb-3'>
  22. <div className='
  23. w-12 h-12 flex items-center justify-center rounded-xl
  24. bg-white border-[0.5px] border-gray-100
  25. shadow-[0px_20px_24px_-4px_rgba(16,24,40,0.08),0px_8px_8px_-4px_rgba(16,24,40,0.03)]
  26. '>
  27. <CheckCircleIcon className='w-[22px] h-[22px] text-[#039855]' />
  28. </div>
  29. <XMarkIcon className='w-4 h-4 cursor-pointer' onClick={onCancel} />
  30. </div>
  31. <div className='mb-1 text-xl font-semibold text-gray-900'>{t('common.members.invitationSent')}</div>
  32. {!IS_CE_EDITION && (
  33. <div className='mb-10 text-sm text-gray-500'>{t('common.members.invitationSentTip')}</div>
  34. )}
  35. {IS_CE_EDITION && (
  36. <>
  37. <div className='mb-5 text-sm text-gray-500'>{t('common.members.invitationSentTip')}</div>
  38. <div className='mb-9'>
  39. <div className='py-2 text-sm font-Medium text-gray-900'>{t('common.members.invitationLink')}</div>
  40. <InvitationLink value={invitationLink} />
  41. </div>
  42. </>
  43. )}
  44. <div className='flex justify-end'>
  45. <Button
  46. className='w-[96px] text-sm font-medium'
  47. onClick={onCancel}
  48. type='primary'
  49. >
  50. {t('common.members.ok')}
  51. </Button>
  52. </div>
  53. </Modal>
  54. </div>
  55. )
  56. }
  57. export default InvitedModal