| 
									
										
										
										
											2024-01-23 19:31:56 +08:00
										 |  |  | 'use client' | 
					
						
							|  |  |  | import type { FC } from 'react' | 
					
						
							|  |  |  | import React from 'react' | 
					
						
							|  |  |  | import { useContext } from 'use-context-selector' | 
					
						
							|  |  |  | import cn from 'classnames' | 
					
						
							|  |  |  | import AppIcon from '../../base/app-icon' | 
					
						
							|  |  |  | import type { Collection } from '@/app/components/tools/types' | 
					
						
							|  |  |  | import I18n from '@/context/i18n' | 
					
						
							| 
									
										
										
										
											2024-02-23 14:31:06 +08:00
										 |  |  | import { getLanguage } from '@/i18n/language' | 
					
						
							| 
									
										
										
										
											2024-01-23 19:31:56 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | type Props = { | 
					
						
							|  |  |  |   isCurrent: boolean | 
					
						
							|  |  |  |   payload: Collection | 
					
						
							|  |  |  |   onClick: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const Item: FC<Props> = ({ | 
					
						
							|  |  |  |   isCurrent, | 
					
						
							|  |  |  |   payload, | 
					
						
							|  |  |  |   onClick, | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const { locale } = useContext(I18n) | 
					
						
							| 
									
										
										
										
											2024-02-23 14:31:06 +08:00
										 |  |  |   const language = getLanguage(locale) | 
					
						
							| 
									
										
										
										
											2024-01-23 19:31:56 +08:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <div | 
					
						
							|  |  |  |       className={cn(isCurrent && 'bg-white shadow-xs rounded-lg', 'mt-1 flex h-9 items-center px-2 space-x-2 cursor-pointer')} | 
					
						
							|  |  |  |       onClick={() => !isCurrent && onClick()} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       {typeof payload.icon === 'string' | 
					
						
							|  |  |  |         ? ( | 
					
						
							|  |  |  |           <div | 
					
						
							|  |  |  |             className='w-6 h-6 bg-cover bg-center rounded-md' | 
					
						
							|  |  |  |             style={{ | 
					
						
							|  |  |  |               backgroundImage: `url(${payload.icon})`, | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |           ></div> | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         : ( | 
					
						
							|  |  |  |           <AppIcon | 
					
						
							|  |  |  |             size='tiny' | 
					
						
							|  |  |  |             icon={payload.icon.content} | 
					
						
							|  |  |  |             background={payload.icon.background} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         )} | 
					
						
							| 
									
										
										
										
											2024-01-24 11:08:11 +08:00
										 |  |  |       <div className={cn(isCurrent && 'text-primary-600 font-semibold', 'leading-5 text-sm font-normal truncate')}>{payload.label[language]}</div> | 
					
						
							| 
									
										
										
										
											2024-01-23 19:31:56 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | export default React.memo(Item) |