| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  | import type { FC } from 'react' | 
					
						
							|  |  |  | import classNames from '@/utils/classnames' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type Step = { | 
					
						
							|  |  |  |   name: string | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type StepperStepProps = Step & { | 
					
						
							|  |  |  |   index: number | 
					
						
							|  |  |  |   activeIndex: number | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const StepperStep: FC<StepperStepProps> = (props) => { | 
					
						
							|  |  |  |   const { name, activeIndex, index } = props | 
					
						
							|  |  |  |   const isActive = index === activeIndex | 
					
						
							|  |  |  |   const isDisabled = activeIndex < index | 
					
						
							|  |  |  |   const label = isActive ? `STEP ${index + 1}` : `${index + 1}` | 
					
						
							|  |  |  |   return <div className='flex items-center gap-2'> | 
					
						
							|  |  |  |     <div className={classNames( | 
					
						
							| 
									
										
										
										
											2025-04-06 00:04:56 +08:00
										 |  |  |       'h-5 py-1 rounded-3xl flex-col justify-center items-center gap-2 inline-flex', | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |       isActive | 
					
						
							| 
									
										
										
										
											2025-04-06 00:04:56 +08:00
										 |  |  |         ? 'px-2 bg-state-accent-solid' | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |         : !isDisabled | 
					
						
							| 
									
										
										
										
											2025-04-06 00:04:56 +08:00
										 |  |  |           ? 'w-5 border border-text-quaternary' | 
					
						
							|  |  |  |           : 'w-5 border border-divider-deep', | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |     )}> | 
					
						
							|  |  |  |       <div className={classNames( | 
					
						
							|  |  |  |         'text-center system-2xs-semibold-uppercase', | 
					
						
							|  |  |  |         isActive | 
					
						
							|  |  |  |           ? 'text-text-primary-on-surface' | 
					
						
							|  |  |  |           : !isDisabled | 
					
						
							|  |  |  |             ? 'text-text-tertiary' | 
					
						
							|  |  |  |             : 'text-text-quaternary', | 
					
						
							|  |  |  |       )}> | 
					
						
							|  |  |  |         {label} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |     <div className={classNames('system-xs-medium-uppercase', | 
					
						
							|  |  |  |       isActive | 
					
						
							|  |  |  |         ? 'text-text-accent system-xs-semibold-uppercase' | 
					
						
							|  |  |  |         : !isDisabled | 
					
						
							|  |  |  |           ? 'text-text-tertiary' | 
					
						
							|  |  |  |           : 'text-text-quaternary', | 
					
						
							|  |  |  |     )}>{name}</div> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | } |