| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 'use client' | 
					
						
							|  |  |  | import { Dialog } from '@headlessui/react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  | import { XMarkIcon } from '@heroicons/react/24/outline' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import Button from '../button' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  | export type IDrawerProps = { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   title?: string | 
					
						
							|  |  |  |   description?: string | 
					
						
							|  |  |  |   panelClassname?: string | 
					
						
							|  |  |  |   children: React.ReactNode | 
					
						
							|  |  |  |   footer?: React.ReactNode | 
					
						
							|  |  |  |   mask?: boolean | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   positionCenter?: boolean | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   isOpen: boolean | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  |   showClose?: boolean | 
					
						
							| 
									
										
										
										
											2023-12-18 15:41:24 +08:00
										 |  |  |   clickOutsideNotOpen?: boolean | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   onClose: () => void | 
					
						
							|  |  |  |   onCancel?: () => void | 
					
						
							|  |  |  |   onOk?: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default function Drawer({ | 
					
						
							|  |  |  |   title = '', | 
					
						
							|  |  |  |   description = '', | 
					
						
							|  |  |  |   panelClassname = '', | 
					
						
							|  |  |  |   children, | 
					
						
							|  |  |  |   footer, | 
					
						
							|  |  |  |   mask = true, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   positionCenter, | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  |   showClose = false, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   isOpen, | 
					
						
							| 
									
										
										
										
											2023-12-18 15:41:24 +08:00
										 |  |  |   clickOutsideNotOpen, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   onClose, | 
					
						
							|  |  |  |   onCancel, | 
					
						
							|  |  |  |   onOk, | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  | }: IDrawerProps) { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Dialog | 
					
						
							|  |  |  |       unmount={false} | 
					
						
							|  |  |  |       open={isOpen} | 
					
						
							| 
									
										
										
										
											2023-12-18 15:41:24 +08:00
										 |  |  |       onClose={() => !clickOutsideNotOpen && onClose()} | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |       className="fixed z-30 inset-0 overflow-y-auto" | 
					
						
							|  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |       <div className={cn('flex w-screen h-screen justify-end', positionCenter && '!justify-center')}> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         {/* mask */} | 
					
						
							|  |  |  |         <Dialog.Overlay | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |           className={cn('z-40 fixed inset-0', mask && 'bg-black bg-opacity-30')} | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         /> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         <div className={cn('relative z-50 flex flex-col justify-between bg-white w-full max-w-sm p-6 overflow-hidden text-left align-middle shadow-xl', panelClassname)}> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |           <> | 
					
						
							|  |  |  |             {title && <Dialog.Title | 
					
						
							|  |  |  |               as="h3" | 
					
						
							|  |  |  |               className="text-lg font-medium leading-6 text-gray-900" | 
					
						
							|  |  |  |             > | 
					
						
							|  |  |  |               {title} | 
					
						
							|  |  |  |             </Dialog.Title>} | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  |             {showClose && <Dialog.Title className="flex items-center mb-4" as="div"> | 
					
						
							|  |  |  |               <XMarkIcon className='w-4 h-4 text-gray-500' onClick={onClose} /> | 
					
						
							|  |  |  |             </Dialog.Title>} | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |             {description && <Dialog.Description className='text-gray-500 text-xs font-normal mt-2'>{description}</Dialog.Description>} | 
					
						
							|  |  |  |             {children} | 
					
						
							|  |  |  |           </> | 
					
						
							|  |  |  |           {footer || (footer === null | 
					
						
							|  |  |  |             ? null | 
					
						
							|  |  |  |             : <div className="mt-10 flex flex-row justify-end"> | 
					
						
							|  |  |  |               <Button | 
					
						
							|  |  |  |                 className='mr-2' | 
					
						
							|  |  |  |                 onClick={() => { | 
					
						
							|  |  |  |                   onCancel && onCancel() | 
					
						
							|  |  |  |                 }}>{t('common.operation.cancel')}</Button> | 
					
						
							|  |  |  |               <Button | 
					
						
							|  |  |  |                 onClick={() => { | 
					
						
							|  |  |  |                   onOk && onOk() | 
					
						
							|  |  |  |                 }}>{t('common.operation.save')}</Button> | 
					
						
							|  |  |  |             </div>)} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </Dialog> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } |