| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  | import { Dialog, DialogPanel, DialogTitle, Transition, TransitionChild } from '@headlessui/react' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import { Fragment } from 'react' | 
					
						
							| 
									
										
										
										
											2024-12-23 11:17:49 +08:00
										 |  |  | import { RiCloseLine } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import classNames from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  | import { noop } from 'lodash-es' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | // https://headlessui.com/react/dialog
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type IModal = { | 
					
						
							|  |  |  |   className?: string | 
					
						
							| 
									
										
										
										
											2023-05-17 19:05:51 +08:00
										 |  |  |   wrapperClassName?: string | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   isShow: boolean | 
					
						
							| 
									
										
										
										
											2024-06-05 00:13:29 +08:00
										 |  |  |   onClose?: () => void | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   title?: React.ReactNode | 
					
						
							|  |  |  |   description?: React.ReactNode | 
					
						
							| 
									
										
										
										
											2024-06-05 00:13:29 +08:00
										 |  |  |   children?: React.ReactNode | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   closable?: boolean | 
					
						
							| 
									
										
										
										
											2023-05-31 14:10:59 +08:00
										 |  |  |   overflowVisible?: boolean | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default function Modal({ | 
					
						
							|  |  |  |   className, | 
					
						
							| 
									
										
										
										
											2023-05-17 19:05:51 +08:00
										 |  |  |   wrapperClassName, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   isShow, | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  |   onClose = noop, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   title, | 
					
						
							|  |  |  |   description, | 
					
						
							|  |  |  |   children, | 
					
						
							|  |  |  |   closable = false, | 
					
						
							| 
									
										
										
										
											2023-05-31 14:10:59 +08:00
										 |  |  |   overflowVisible = false, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | }: IModal) { | 
					
						
							|  |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |     <Transition appear show={isShow} as={Fragment}> | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  |       <Dialog as="div" className={classNames('relative z-[60]', wrapperClassName)} onClose={onClose}> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |         <TransitionChild> | 
					
						
							|  |  |  |           <div className={classNames( | 
					
						
							|  |  |  |             'fixed inset-0 bg-background-overlay', | 
					
						
							|  |  |  |             'duration-300 ease-in data-[closed]:opacity-0', | 
					
						
							|  |  |  |             'data-[enter]:opacity-100', | 
					
						
							|  |  |  |             'data-[leave]:opacity-0', | 
					
						
							|  |  |  |           )} /> | 
					
						
							|  |  |  |         </TransitionChild> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-22 19:53:20 +08:00
										 |  |  |         <div | 
					
						
							|  |  |  |           className="fixed inset-0 overflow-y-auto" | 
					
						
							|  |  |  |           onClick={(e) => { | 
					
						
							|  |  |  |             e.preventDefault() | 
					
						
							|  |  |  |             e.stopPropagation() | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |         > | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |           <div className="flex min-h-full items-center justify-center p-4 text-center"> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |             <TransitionChild> | 
					
						
							|  |  |  |               <DialogPanel className={classNames( | 
					
						
							| 
									
										
										
										
											2024-12-12 10:09:48 +08:00
										 |  |  |                 'w-full max-w-[480px] transform rounded-2xl bg-components-panel-bg p-6 text-left align-middle shadow-xl transition-all', | 
					
						
							| 
									
										
										
										
											2024-06-05 00:13:29 +08:00
										 |  |  |                 overflowVisible ? 'overflow-visible' : 'overflow-hidden', | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 'duration-100 ease-in data-[closed]:opacity-0 data-[closed]:scale-95', | 
					
						
							|  |  |  |                 'data-[enter]:opacity-100 data-[enter]:scale-100', | 
					
						
							|  |  |  |                 'data-[leave]:opacity-0 data-[enter]:scale-95', | 
					
						
							| 
									
										
										
										
											2024-06-05 00:13:29 +08:00
										 |  |  |                 className, | 
					
						
							|  |  |  |               )}> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 {title && <DialogTitle | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |                   as="h3" | 
					
						
							| 
									
										
										
										
											2024-12-23 11:17:49 +08:00
										 |  |  |                   className="title-2xl-semi-bold text-text-primary" | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |                 > | 
					
						
							|  |  |  |                   {title} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 </DialogTitle>} | 
					
						
							|  |  |  |                 {description && <div className='body-md-regular mt-2 text-text-secondary'> | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |                   {description} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 </div>} | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |                 {closable | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                   && <div className='absolute right-6 top-6 z-10 flex h-5 w-5 items-center justify-center rounded-2xl hover:cursor-pointer hover:bg-state-base-hover'> | 
					
						
							|  |  |  |                     <RiCloseLine className='h-4 w-4 text-text-tertiary' onClick={ | 
					
						
							| 
									
										
										
										
											2023-12-18 15:41:24 +08:00
										 |  |  |                       (e) => { | 
					
						
							|  |  |  |                         e.stopPropagation() | 
					
						
							|  |  |  |                         onClose() | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                     } /> | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |                   </div>} | 
					
						
							|  |  |  |                 {children} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               </DialogPanel> | 
					
						
							|  |  |  |             </TransitionChild> | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </Dialog> | 
					
						
							|  |  |  |     </Transition> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   ) | 
					
						
							|  |  |  | } |