refactor: move content of src/ to root dir for readability
				
					
				
			This commit is contained in:
		
							parent
							
								
									87958d1d28
								
							
						
					
					
						commit
						532d1eba99
					
				
					 69 changed files with 5 additions and 4 deletions
				
			
		|  | @ -1,64 +0,0 @@ | |||
| import Link from 'next/link' | ||||
| import clsx from 'clsx' | ||||
| import { ReactNode } from 'react' | ||||
| 
 | ||||
| const baseStyles = { | ||||
|   solid: | ||||
|     'group inline-flex items-center justify-center rounded-full py-2 px-4 text-sm font-semibold focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2', | ||||
|   outline: | ||||
|     'group inline-flex ring-1 items-center justify-center rounded-full py-2 px-4 text-sm focus:outline-none', | ||||
| } | ||||
| 
 | ||||
| const variantStyles = { | ||||
|   solid: { | ||||
|     slate: | ||||
|       'bg-slate-900 text-white hover:bg-slate-700 hover:text-slate-100 active:bg-slate-800 active:text-slate-300 focus-visible:outline-slate-900', | ||||
|     blue: 'bg-blue-600 text-white hover:text-slate-100 hover:bg-blue-500 active:bg-blue-800 active:text-blue-100 focus-visible:outline-blue-600', | ||||
|     white: | ||||
|       'bg-white text-slate-900 hover:bg-blue-50 active:bg-blue-200 active:text-slate-600 focus-visible:outline-white', | ||||
|   }, | ||||
|   outline: { | ||||
|     slate: | ||||
|       'ring-slate-200 text-slate-700 hover:text-slate-900 hover:ring-slate-300 active:bg-slate-100 active:text-slate-600 focus-visible:outline-blue-600 focus-visible:ring-slate-300', | ||||
|     white: | ||||
|       'ring-slate-700 text-white hover:ring-slate-500 active:ring-slate-700 active:text-slate-400 focus-visible:outline-white', | ||||
|     blue: // Supress TypeScript error
 | ||||
|       '', // TODO: fix properly
 | ||||
|   }, | ||||
| } | ||||
| 
 | ||||
| type Props = { | ||||
|   variant?: 'solid'|'outline', | ||||
|   color?: 'slate'|'white'|'blue', | ||||
|   className?: string, | ||||
|   href?: string, | ||||
|   children?: ReactNode, | ||||
| } | ||||
| 
 | ||||
| export function Button({ | ||||
|   variant = 'solid', | ||||
|   color = 'slate', | ||||
|   className, | ||||
|   href, | ||||
|   children | ||||
| }: Props) { | ||||
|   className = clsx( | ||||
|     baseStyles[variant], | ||||
|     variantStyles[variant][color], | ||||
|     className | ||||
|   ) | ||||
| 
 | ||||
|   if (href !== undefined) { | ||||
|     return ( | ||||
|       <Link href={href} className={className}> | ||||
|         {children} | ||||
|       </Link> | ||||
|     ) | ||||
|   } else { | ||||
|     return ( | ||||
|       <button className={className}> | ||||
|         {children} | ||||
|       </button> | ||||
|     ) | ||||
|   } | ||||
| } | ||||
		Reference in a new issue