| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  | 'use client' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  | import type { FC } from 'react' | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  | import { init } from 'emoji-mart' | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  | import data from '@emoji-mart/data' | 
					
						
							| 
									
										
										
										
											2023-06-01 23:19:36 +08:00
										 |  |  | import style from './style.module.css' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import classNames from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  | import type { AppIconType } from '@/types/app' | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | init({ data }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | export type AppIconProps = { | 
					
						
							| 
									
										
										
										
											2024-01-23 19:31:56 +08:00
										 |  |  |   size?: 'xs' | 'tiny' | 'small' | 'medium' | 'large' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   rounded?: boolean | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  |   iconType?: AppIconType | null | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   icon?: string | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  |   background?: string | null | 
					
						
							|  |  |  |   imageUrl?: string | null | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   className?: string | 
					
						
							|  |  |  |   innerIcon?: React.ReactNode | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |   onClick?: () => void | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const AppIcon: FC<AppIconProps> = ({ | 
					
						
							|  |  |  |   size = 'medium', | 
					
						
							|  |  |  |   rounded = false, | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  |   iconType, | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |   icon, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   background, | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  |   imageUrl, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   className, | 
					
						
							|  |  |  |   innerIcon, | 
					
						
							| 
									
										
										
										
											2023-05-19 17:36:44 +08:00
										 |  |  |   onClick, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | }) => { | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  |   const wrapperClassName = classNames( | 
					
						
							|  |  |  |     style.appIcon, | 
					
						
							|  |  |  |     size !== 'medium' && style[size], | 
					
						
							|  |  |  |     rounded && style.rounded, | 
					
						
							|  |  |  |     className ?? '', | 
					
						
							|  |  |  |     'overflow-hidden', | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   ) | 
					
						
							| 
									
										
										
										
											2024-08-19 09:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const isValidImageIcon = iconType === 'image' && imageUrl | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return <span | 
					
						
							|  |  |  |     className={wrapperClassName} | 
					
						
							|  |  |  |     style={{ background: isValidImageIcon ? undefined : (background || '#FFEAD5') }} | 
					
						
							|  |  |  |     onClick={onClick} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {isValidImageIcon | 
					
						
							|  |  |  |       ? <img src={imageUrl} className="w-full h-full" alt="app icon" /> | 
					
						
							|  |  |  |       : (innerIcon || ((icon && icon !== '') ? <em-emoji id={icon} /> : <em-emoji id='🤖' />)) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   </span> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default AppIcon |