| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  | 'use client' | 
					
						
							|  |  |  | import type { FC } from 'react' | 
					
						
							|  |  |  | import React, { useState } from 'react' | 
					
						
							|  |  |  | import { PortalToFollowElem, PortalToFollowElemContent, PortalToFollowElemTrigger } from '@/app/components/base/portal-to-follow-elem' | 
					
						
							|  |  |  | export type TooltipProps = { | 
					
						
							|  |  |  |   position?: 'top' | 'right' | 'bottom' | 'left' | 
					
						
							|  |  |  |   triggerMethod?: 'hover' | 'click' | 
					
						
							|  |  |  |   popupContent: React.ReactNode | 
					
						
							|  |  |  |   children: React.ReactNode | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   hideArrow?: boolean | 
					
						
							| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const arrow = ( | 
					
						
							|  |  |  |   <svg className="absolute text-white h-2 w-full left-0 top-full" x="0px" y="0px" viewBox="0 0 255 255"><polygon className="fill-current" points="0,0 127.5,127.5 255,0"></polygon></svg> | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-13 16:41:40 +08:00
										 |  |  | const Tooltip: FC<TooltipProps> = ({ | 
					
						
							| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  |   position = 'top', | 
					
						
							|  |  |  |   triggerMethod = 'hover', | 
					
						
							|  |  |  |   popupContent, | 
					
						
							|  |  |  |   children, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   hideArrow, | 
					
						
							| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  | }) => { | 
					
						
							|  |  |  |   const [open, setOpen] = useState(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <PortalToFollowElem | 
					
						
							|  |  |  |       open={open} | 
					
						
							|  |  |  |       onOpenChange={setOpen} | 
					
						
							|  |  |  |       placement={position} | 
					
						
							|  |  |  |       offset={10} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       <PortalToFollowElemTrigger | 
					
						
							|  |  |  |         onClick={() => triggerMethod === 'click' && setOpen(v => !v)} | 
					
						
							|  |  |  |         onMouseEnter={() => triggerMethod === 'hover' && setOpen(true)} | 
					
						
							|  |  |  |         onMouseLeave={() => triggerMethod === 'hover' && setOpen(false)} | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         {children} | 
					
						
							|  |  |  |       </PortalToFollowElemTrigger> | 
					
						
							|  |  |  |       <PortalToFollowElemContent | 
					
						
							| 
									
										
										
										
											2023-12-13 16:41:40 +08:00
										 |  |  |         className="z-[9999]" | 
					
						
							| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  |       > | 
					
						
							|  |  |  |         <div className='relative px-3 py-2 text-xs font-normal text-gray-700 bg-white rounded-md shadow-lg'> | 
					
						
							|  |  |  |           {popupContent} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |           {!hideArrow && arrow} | 
					
						
							| 
									
										
										
										
											2023-09-10 00:12:34 +08:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       </PortalToFollowElemContent> | 
					
						
							|  |  |  |     </PortalToFollowElem> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default React.memo(Tooltip) |