init
This commit is contained in:
		
							parent
							
								
									f75bb39e53
								
							
						
					
					
						commit
						38a8a47ef3
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -31,6 +31,7 @@ yarn-error.log* | ||||
| 
 | ||||
| # env files (can opt-in for committing if needed) | ||||
| .env* | ||||
| .env.local | ||||
| 
 | ||||
| # vercel | ||||
| .vercel | ||||
|  | ||||
							
								
								
									
										21
									
								
								components.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								components.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| { | ||||
|   "$schema": "https://ui.shadcn.com/schema.json", | ||||
|   "style": "new-york", | ||||
|   "rsc": true, | ||||
|   "tsx": true, | ||||
|   "tailwind": { | ||||
|     "config": "tailwind.config.ts", | ||||
|     "css": "src/app/globals.css", | ||||
|     "baseColor": "zinc", | ||||
|     "cssVariables": true, | ||||
|     "prefix": "" | ||||
|   }, | ||||
|   "aliases": { | ||||
|     "components": "@/components", | ||||
|     "utils": "@/lib/utils", | ||||
|     "ui": "@/components/ui", | ||||
|     "lib": "@/lib", | ||||
|     "hooks": "@/hooks" | ||||
|   }, | ||||
|   "iconLibrary": "lucide" | ||||
| } | ||||
							
								
								
									
										19
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								package.json
									
									
									
									
									
								
							| @ -9,18 +9,29 @@ | ||||
|     "lint": "next lint" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@hookform/resolvers": "^3.9.1", | ||||
|     "@radix-ui/react-label": "^2.1.0", | ||||
|     "@radix-ui/react-select": "^2.1.2", | ||||
|     "@radix-ui/react-slot": "^1.1.0", | ||||
|     "class-variance-authority": "^0.7.1", | ||||
|     "clsx": "^2.1.1", | ||||
|     "lucide-react": "^0.462.0", | ||||
|     "next": "15.0.3", | ||||
|     "react": "19.0.0-rc-66855b96-20241106", | ||||
|     "react-dom": "19.0.0-rc-66855b96-20241106", | ||||
|     "next": "15.0.3" | ||||
|     "react-hook-form": "^7.53.2", | ||||
|     "tailwind-merge": "^2.5.5", | ||||
|     "tailwindcss-animate": "^1.0.7", | ||||
|     "zod": "^3.23.8" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "typescript": "^5", | ||||
|     "@types/node": "^20", | ||||
|     "@types/react": "^18", | ||||
|     "@types/react-dom": "^18", | ||||
|     "eslint": "^8", | ||||
|     "eslint-config-next": "15.0.3", | ||||
|     "postcss": "^8", | ||||
|     "tailwindcss": "^3.4.1", | ||||
|     "eslint": "^8", | ||||
|     "eslint-config-next": "15.0.3" | ||||
|     "typescript": "^5" | ||||
|   } | ||||
| } | ||||
|  | ||||
							
								
								
									
										752
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										752
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @ -8,6 +8,27 @@ importers: | ||||
| 
 | ||||
|   .: | ||||
|     dependencies: | ||||
|       '@hookform/resolvers': | ||||
|         specifier: ^3.9.1 | ||||
|         version: 3.9.1(react-hook-form@7.53.2(react@19.0.0-rc-66855b96-20241106)) | ||||
|       '@radix-ui/react-label': | ||||
|         specifier: ^2.1.0 | ||||
|         version: 2.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-select': | ||||
|         specifier: ^2.1.2 | ||||
|         version: 2.1.2(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-slot': | ||||
|         specifier: ^1.1.0 | ||||
|         version: 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       class-variance-authority: | ||||
|         specifier: ^0.7.1 | ||||
|         version: 0.7.1 | ||||
|       clsx: | ||||
|         specifier: ^2.1.1 | ||||
|         version: 2.1.1 | ||||
|       lucide-react: | ||||
|         specifier: ^0.462.0 | ||||
|         version: 0.462.0(react@19.0.0-rc-66855b96-20241106) | ||||
|       next: | ||||
|         specifier: 15.0.3 | ||||
|         version: 15.0.3(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
| @ -17,6 +38,18 @@ importers: | ||||
|       react-dom: | ||||
|         specifier: 19.0.0-rc-66855b96-20241106 | ||||
|         version: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|       react-hook-form: | ||||
|         specifier: ^7.53.2 | ||||
|         version: 7.53.2(react@19.0.0-rc-66855b96-20241106) | ||||
|       tailwind-merge: | ||||
|         specifier: ^2.5.5 | ||||
|         version: 2.5.5 | ||||
|       tailwindcss-animate: | ||||
|         specifier: ^1.0.7 | ||||
|         version: 1.0.7(tailwindcss@3.4.15) | ||||
|       zod: | ||||
|         specifier: ^3.23.8 | ||||
|         version: 3.23.8 | ||||
|     devDependencies: | ||||
|       '@types/node': | ||||
|         specifier: ^20 | ||||
| @ -70,6 +103,26 @@ packages: | ||||
|     resolution: {integrity: sha512-d9zaMRSTIKDLhctzH12MtXvJKSSUhaHcjV+2Z+GK+EEY7XKpP5yR4x+N3TAcHTcu963nIr+TMcCb4DBCYX1z6Q==} | ||||
|     engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} | ||||
| 
 | ||||
|   '@floating-ui/core@1.6.8': | ||||
|     resolution: {integrity: sha512-7XJ9cPU+yI2QeLS+FCSlqNFZJq8arvswefkZrYI1yQBbftw6FyrZOxYSh+9S7z7TpeWlRt9zJ5IhM1WIL334jA==} | ||||
| 
 | ||||
|   '@floating-ui/dom@1.6.12': | ||||
|     resolution: {integrity: sha512-NP83c0HjokcGVEMeoStg317VD9W7eDlGK7457dMBANbKA6GJZdc7rjujdgqzTaz93jkGgc5P/jeWbaCHnMNc+w==} | ||||
| 
 | ||||
|   '@floating-ui/react-dom@2.1.2': | ||||
|     resolution: {integrity: sha512-06okr5cgPzMNBy+Ycse2A6udMi4bqwW/zgBF/rwjcNqWkyr82Mcg8b0vjX8OJpZFy/FKjJmw6wV7t44kK6kW7A==} | ||||
|     peerDependencies: | ||||
|       react: '>=16.8.0' | ||||
|       react-dom: '>=16.8.0' | ||||
| 
 | ||||
|   '@floating-ui/utils@0.2.8': | ||||
|     resolution: {integrity: sha512-kym7SodPp8/wloecOpcmSnWJsK7M0E5Wg8UcFA+uO4B9s5d0ywXOEro/8HM9x0rW+TljRzul/14UYz3TleT3ig==} | ||||
| 
 | ||||
|   '@hookform/resolvers@3.9.1': | ||||
|     resolution: {integrity: sha512-ud2HqmGBM0P0IABqoskKWI6PEf6ZDDBZkFqe2Vnl+mTHCEHzr3ISjjZyCwTjC/qpL25JC9aIDkloQejvMeq0ug==} | ||||
|     peerDependencies: | ||||
|       react-hook-form: ^7.0.0 | ||||
| 
 | ||||
|   '@humanwhocodes/config-array@0.13.0': | ||||
|     resolution: {integrity: sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw==} | ||||
|     engines: {node: '>=10.10.0'} | ||||
| @ -284,6 +337,271 @@ packages: | ||||
|     resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} | ||||
|     engines: {node: '>=14'} | ||||
| 
 | ||||
|   '@radix-ui/number@1.1.0': | ||||
|     resolution: {integrity: sha512-V3gRzhVNU1ldS5XhAPTom1fOIo4ccrjjJgmE+LI2h/WaFpHmx0MQApT+KZHnx8abG6Avtfcz4WoEciMnpFT3HQ==} | ||||
| 
 | ||||
|   '@radix-ui/primitive@1.1.0': | ||||
|     resolution: {integrity: sha512-4Z8dn6Upk0qk4P74xBhZ6Hd/w0mPEzOOLxy4xiPXOXqjF7jZS0VAKk7/x/H6FyY2zCkYJqePf1G5KmkmNJ4RBA==} | ||||
| 
 | ||||
|   '@radix-ui/react-arrow@1.1.0': | ||||
|     resolution: {integrity: sha512-FmlW1rCg7hBpEBwFbjHwCW6AmWLQM6g/v0Sn8XbP9NvmSZ2San1FpQeyPtufzOMSIx7Y4dzjlHoifhp+7NkZhw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-collection@1.1.0': | ||||
|     resolution: {integrity: sha512-GZsZslMJEyo1VKm5L1ZJY8tGDxZNPAoUeQUIbKeJfoi7Q4kmig5AsgLMYYuyYbfjd8fBmFORAIwYAkXMnXZgZw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-compose-refs@1.1.0': | ||||
|     resolution: {integrity: sha512-b4inOtiaOnYf9KWyO3jAeeCG6FeyfY6ldiEPanbUjWd+xIk5wZeHa8yVwmrJ2vderhu/BQvzCrJI0lHd+wIiqw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-context@1.1.0': | ||||
|     resolution: {integrity: sha512-OKrckBy+sMEgYM/sMmqmErVn0kZqrHPJze+Ql3DzYsDDp0hl0L62nx/2122/Bvps1qz645jlcu2tD9lrRSdf8A==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-context@1.1.1': | ||||
|     resolution: {integrity: sha512-UASk9zi+crv9WteK/NU4PLvOoL3OuE6BWVKNF6hPRBtYBDXQ2u5iu3O59zUlJiTVvkyuycnqrztsHVJwcK9K+Q==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-direction@1.1.0': | ||||
|     resolution: {integrity: sha512-BUuBvgThEiAXh2DWu93XsT+a3aWrGqolGlqqw5VU1kG7p/ZH2cuDlM1sRLNnY3QcBS69UIz2mcKhMxDsdewhjg==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-dismissable-layer@1.1.1': | ||||
|     resolution: {integrity: sha512-QSxg29lfr/xcev6kSz7MAlmDnzbP1eI/Dwn3Tp1ip0KT5CUELsxkekFEMVBEoykI3oV39hKT4TKZzBNMbcTZYQ==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-focus-guards@1.1.1': | ||||
|     resolution: {integrity: sha512-pSIwfrT1a6sIoDASCSpFwOasEwKTZWDw/iBdtnqKO7v6FeOzYJ7U53cPzYFVR3geGGXgVHaH+CdngrrAzqUGxg==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-focus-scope@1.1.0': | ||||
|     resolution: {integrity: sha512-200UD8zylvEyL8Bx+z76RJnASR2gRMuxlgFCPAe/Q/679a/r0eK3MBVYMb7vZODZcffZBdob1EGnky78xmVvcA==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-id@1.1.0': | ||||
|     resolution: {integrity: sha512-EJUrI8yYh7WOjNOqpoJaf1jlFIH2LvtgAl+YcFqNCa+4hj64ZXmPkAKOFs/ukjz3byN6bdb/AVUqHkI8/uWWMA==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-label@2.1.0': | ||||
|     resolution: {integrity: sha512-peLblDlFw/ngk3UWq0VnYaOLy6agTZZ+MUO/WhVfm14vJGML+xH4FAl2XQGLqdefjNb7ApRg6Yn7U42ZhmYXdw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-popper@1.2.0': | ||||
|     resolution: {integrity: sha512-ZnRMshKF43aBxVWPWvbj21+7TQCvhuULWJ4gNIKYpRlQt5xGRhLx66tMp8pya2UkGHTSlhpXwmjqltDYHhw7Vg==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-portal@1.1.2': | ||||
|     resolution: {integrity: sha512-WeDYLGPxJb/5EGBoedyJbT0MpoULmwnIPMJMSldkuiMsBAv7N1cRdsTWZWht9vpPOiN3qyiGAtbK2is47/uMFg==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-primitive@2.0.0': | ||||
|     resolution: {integrity: sha512-ZSpFm0/uHa8zTvKBDjLFWLo8dkr4MBsiDLz0g3gMUwqgLHz9rTaRRGYDgvZPtBJgYCBKXkS9fzmoySgr8CO6Cw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-select@2.1.2': | ||||
|     resolution: {integrity: sha512-rZJtWmorC7dFRi0owDmoijm6nSJH1tVw64QGiNIZ9PNLyBDtG+iAq+XGsya052At4BfarzY/Dhv9wrrUr6IMZA==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-slot@1.1.0': | ||||
|     resolution: {integrity: sha512-FUCf5XMfmW4dtYl69pdS4DbxKy8nj4M7SafBgPllysxmdachynNflAdp/gCsnYWNDnge6tI9onzMp5ARYc1KNw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-callback-ref@1.1.0': | ||||
|     resolution: {integrity: sha512-CasTfvsy+frcFkbXtSJ2Zu9JHpN8TYKxkgJGWbjiZhFivxaeW7rMeZt7QELGVLaYVfFMsKHjb7Ak0nMEe+2Vfw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-controllable-state@1.1.0': | ||||
|     resolution: {integrity: sha512-MtfMVJiSr2NjzS0Aa90NPTnvTSg6C/JLCV7ma0W6+OMV78vd8OyRpID+Ng9LxzsPbLeuBnWBA1Nq30AtBIDChw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-escape-keydown@1.1.0': | ||||
|     resolution: {integrity: sha512-L7vwWlR1kTTQ3oh7g1O0CBF3YCyyTj8NmhLR+phShpyA50HCfBFKVJTpshm9PzLiKmehsrQzTYTpX9HvmC9rhw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-layout-effect@1.1.0': | ||||
|     resolution: {integrity: sha512-+FPE0rOdziWSrH9athwI1R0HDVbWlEhd+FR+aSDk4uWGmSJ9Z54sdZVDQPZAinJhJXwfT+qnj969mCsT2gfm5w==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-previous@1.1.0': | ||||
|     resolution: {integrity: sha512-Z/e78qg2YFnnXcW88A4JmTtm4ADckLno6F7OXotmkQfeuCVaKuYzqAATPhVzl3delXE7CxIV8shofPn3jPc5Og==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-rect@1.1.0': | ||||
|     resolution: {integrity: sha512-0Fmkebhr6PiseyZlYAOtLS+nb7jLmpqTrJyv61Pe68MKYW6OWdRE2kI70TaYY27u7H0lajqM3hSMMLFq18Z7nQ==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-use-size@1.1.0': | ||||
|     resolution: {integrity: sha512-XW3/vWuIXHa+2Uwcc2ABSfcCledmXhhQPlGbfcRXbiUQI5Icjcg19BGCZVKKInYbvUCut/ufbbLLPFC5cbb1hw==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/react-visually-hidden@1.1.0': | ||||
|     resolution: {integrity: sha512-N8MDZqtgCgG5S3aV60INAB475osJousYpZ4cTJ2cFbMpdHS5Y6loLTH8LPtkj2QN0x93J30HT/M3qJXM0+lyeQ==} | ||||
|     peerDependencies: | ||||
|       '@types/react': '*' | ||||
|       '@types/react-dom': '*' | ||||
|       react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|       react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
|       '@types/react-dom': | ||||
|         optional: true | ||||
| 
 | ||||
|   '@radix-ui/rect@1.1.0': | ||||
|     resolution: {integrity: sha512-A9+lCBZoaMJlVKcRBz2YByCG+Cp2t6nAnMnNba+XiWxnj6r4JUFqfsgwocMBZU9LPtdxC6wB56ySYpc7LQIoJg==} | ||||
| 
 | ||||
|   '@rtsao/scc@1.1.0': | ||||
|     resolution: {integrity: sha512-zt6OdqaDoOnJ1ZYsCYGt9YmWzDXl4vQdKTyJev62gFhRGKdx7mcT54V9KIjg+d2wi9EXsPvAPKe7i7WjfVWB8g==} | ||||
| 
 | ||||
| @ -418,6 +736,10 @@ packages: | ||||
|   argparse@2.0.1: | ||||
|     resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} | ||||
| 
 | ||||
|   aria-hidden@1.2.4: | ||||
|     resolution: {integrity: sha512-y+CcFFwelSXpLZk/7fMB2mUbGtX9lKycf1MWJ7CaTIERyitVlyQx6C+sxcROU2BAJ24OiZyK+8wj2i8AlBoS3A==} | ||||
|     engines: {node: '>=10'} | ||||
| 
 | ||||
|   aria-query@5.3.2: | ||||
|     resolution: {integrity: sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| @ -513,9 +835,16 @@ packages: | ||||
|     resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==} | ||||
|     engines: {node: '>= 8.10.0'} | ||||
| 
 | ||||
|   class-variance-authority@0.7.1: | ||||
|     resolution: {integrity: sha512-Ka+9Trutv7G8M6WT6SeiRWz792K5qEqIGEGzXKhAE6xOWAY6pPH8U+9IY3oCMv6kqTmLsv7Xh/2w2RigkePMsg==} | ||||
| 
 | ||||
|   client-only@0.0.1: | ||||
|     resolution: {integrity: sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==} | ||||
| 
 | ||||
|   clsx@2.1.1: | ||||
|     resolution: {integrity: sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==} | ||||
|     engines: {node: '>=6'} | ||||
| 
 | ||||
|   color-convert@2.0.1: | ||||
|     resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==} | ||||
|     engines: {node: '>=7.0.0'} | ||||
| @ -596,6 +925,9 @@ packages: | ||||
|     resolution: {integrity: sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==} | ||||
|     engines: {node: '>=8'} | ||||
| 
 | ||||
|   detect-node-es@1.1.0: | ||||
|     resolution: {integrity: sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==} | ||||
| 
 | ||||
|   didyoumean@1.2.2: | ||||
|     resolution: {integrity: sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==} | ||||
| 
 | ||||
| @ -838,6 +1170,10 @@ packages: | ||||
|     resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| 
 | ||||
|   get-nonce@1.0.1: | ||||
|     resolution: {integrity: sha512-FJhYRoDaiatfEkUK8HKlicmu/3SGFD51q3itKDGoSTysQJBnfOcxU5GxnhE1E6soB76MbT0MBtnKJuXyAx+96Q==} | ||||
|     engines: {node: '>=6'} | ||||
| 
 | ||||
|   get-symbol-description@1.0.2: | ||||
|     resolution: {integrity: sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| @ -927,6 +1263,9 @@ packages: | ||||
|     resolution: {integrity: sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| 
 | ||||
|   invariant@2.2.4: | ||||
|     resolution: {integrity: sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==} | ||||
| 
 | ||||
|   is-array-buffer@3.0.4: | ||||
|     resolution: {integrity: sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| @ -1123,6 +1462,11 @@ packages: | ||||
|   lru-cache@10.4.3: | ||||
|     resolution: {integrity: sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==} | ||||
| 
 | ||||
|   lucide-react@0.462.0: | ||||
|     resolution: {integrity: sha512-NTL7EbAao9IFtuSivSZgrAh4fZd09Lr+6MTkqIxuHaH2nnYiYIzXPo06cOxHg9wKLdj6LL8TByG4qpePqwgx/g==} | ||||
|     peerDependencies: | ||||
|       react: ^16.5.1 || ^17.0.0 || ^18.0.0 || ^19.0.0-rc | ||||
| 
 | ||||
|   merge2@1.4.1: | ||||
|     resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==} | ||||
|     engines: {node: '>= 8'} | ||||
| @ -1344,9 +1688,45 @@ packages: | ||||
|     peerDependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
| 
 | ||||
|   react-hook-form@7.53.2: | ||||
|     resolution: {integrity: sha512-YVel6fW5sOeedd1524pltpHX+jgU2u3DSDtXEaBORNdqiNrsX/nUI/iGXONegttg0mJVnfrIkiV0cmTU6Oo2xw==} | ||||
|     engines: {node: '>=18.0.0'} | ||||
|     peerDependencies: | ||||
|       react: ^16.8.0 || ^17 || ^18 || ^19 | ||||
| 
 | ||||
|   react-is@16.13.1: | ||||
|     resolution: {integrity: sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==} | ||||
| 
 | ||||
|   react-remove-scroll-bar@2.3.6: | ||||
|     resolution: {integrity: sha512-DtSYaao4mBmX+HDo5YWYdBWQwYIQQshUV/dVxFxK+KM26Wjwp1gZ6rv6OC3oujI6Bfu6Xyg3TwK533AQutsn/g==} | ||||
|     engines: {node: '>=10'} | ||||
|     peerDependencies: | ||||
|       '@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|       react: ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   react-remove-scroll@2.6.0: | ||||
|     resolution: {integrity: sha512-I2U4JVEsQenxDAKaVa3VZ/JeJZe0/2DxPWL8Tj8yLKctQJQiZM52pn/GWFpSp8dftjM3pSAHVJZscAnC/y+ySQ==} | ||||
|     engines: {node: '>=10'} | ||||
|     peerDependencies: | ||||
|       '@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|       react: ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   react-style-singleton@2.2.1: | ||||
|     resolution: {integrity: sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==} | ||||
|     engines: {node: '>=10'} | ||||
|     peerDependencies: | ||||
|       '@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|       react: ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   react@19.0.0-rc-66855b96-20241106: | ||||
|     resolution: {integrity: sha512-klH7xkT71SxRCx4hb1hly5FJB21Hz0ACyxbXYAECEqssUjtJeFUAaI2U1DgJAzkGEnvEm3DkxuBchMC/9K4ipg==} | ||||
|     engines: {node: '>=0.10.0'} | ||||
| @ -1524,6 +1904,14 @@ packages: | ||||
|     resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| 
 | ||||
|   tailwind-merge@2.5.5: | ||||
|     resolution: {integrity: sha512-0LXunzzAZzo0tEPxV3I297ffKZPlKDrjj7NXphC8V5ak9yHC5zRmxnOe2m/Rd/7ivsOMJe3JZ2JVocoDdQTRBA==} | ||||
| 
 | ||||
|   tailwindcss-animate@1.0.7: | ||||
|     resolution: {integrity: sha512-bl6mpH3T7I3UFxuvDEXLxy/VuFxBk5bbzplh7tXI68mwMokNYd1t9qPBHlnyTwfa4JGC4zP516I1hYYtQ/vspA==} | ||||
|     peerDependencies: | ||||
|       tailwindcss: '>=3.0.0 || insiders' | ||||
| 
 | ||||
|   tailwindcss@3.4.15: | ||||
|     resolution: {integrity: sha512-r4MeXnfBmSOuKUWmXe6h2CcyfzJCEk4F0pptO5jlnYSIViUkVmsawj80N5h2lO3gwcmSb4n3PuN+e+GC1Guylw==} | ||||
|     engines: {node: '>=14.0.0'} | ||||
| @ -1600,6 +1988,26 @@ packages: | ||||
|   uri-js@4.4.1: | ||||
|     resolution: {integrity: sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==} | ||||
| 
 | ||||
|   use-callback-ref@1.3.2: | ||||
|     resolution: {integrity: sha512-elOQwe6Q8gqZgDA8mrh44qRTQqpIHDcZ3hXTLjBe1i4ph8XpNJnO+aQf3NaG+lriLopI4HMx9VjQLfPQ6vhnoA==} | ||||
|     engines: {node: '>=10'} | ||||
|     peerDependencies: | ||||
|       '@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|       react: ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   use-sidecar@1.1.2: | ||||
|     resolution: {integrity: sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==} | ||||
|     engines: {node: '>=10'} | ||||
|     peerDependencies: | ||||
|       '@types/react': ^16.9.0 || ^17.0.0 || ^18.0.0 | ||||
|       react: ^16.8.0 || ^17.0.0 || ^18.0.0 | ||||
|     peerDependenciesMeta: | ||||
|       '@types/react': | ||||
|         optional: true | ||||
| 
 | ||||
|   util-deprecate@1.0.2: | ||||
|     resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==} | ||||
| 
 | ||||
| @ -1647,6 +2055,9 @@ packages: | ||||
|     resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==} | ||||
|     engines: {node: '>=10'} | ||||
| 
 | ||||
|   zod@3.23.8: | ||||
|     resolution: {integrity: sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==} | ||||
| 
 | ||||
| snapshots: | ||||
| 
 | ||||
|   '@alloc/quick-lru@5.2.0': {} | ||||
| @ -1679,6 +2090,27 @@ snapshots: | ||||
| 
 | ||||
|   '@eslint/js@8.57.1': {} | ||||
| 
 | ||||
|   '@floating-ui/core@1.6.8': | ||||
|     dependencies: | ||||
|       '@floating-ui/utils': 0.2.8 | ||||
| 
 | ||||
|   '@floating-ui/dom@1.6.12': | ||||
|     dependencies: | ||||
|       '@floating-ui/core': 1.6.8 | ||||
|       '@floating-ui/utils': 0.2.8 | ||||
| 
 | ||||
|   '@floating-ui/react-dom@2.1.2(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@floating-ui/dom': 1.6.12 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
| 
 | ||||
|   '@floating-ui/utils@0.2.8': {} | ||||
| 
 | ||||
|   '@hookform/resolvers@3.9.1(react-hook-form@7.53.2(react@19.0.0-rc-66855b96-20241106))': | ||||
|     dependencies: | ||||
|       react-hook-form: 7.53.2(react@19.0.0-rc-66855b96-20241106) | ||||
| 
 | ||||
|   '@humanwhocodes/config-array@0.13.0': | ||||
|     dependencies: | ||||
|       '@humanwhocodes/object-schema': 2.0.3 | ||||
| @ -1839,6 +2271,231 @@ snapshots: | ||||
|   '@pkgjs/parseargs@0.11.0': | ||||
|     optional: true | ||||
| 
 | ||||
|   '@radix-ui/number@1.1.0': {} | ||||
| 
 | ||||
|   '@radix-ui/primitive@1.1.0': {} | ||||
| 
 | ||||
|   '@radix-ui/react-arrow@1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-collection@1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-context': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-slot': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-compose-refs@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-context@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-context@1.1.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-direction@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-dismissable-layer@1.1.1(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/primitive': 1.1.0 | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-escape-keydown': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-focus-guards@1.1.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-focus-scope@1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-id@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-use-layout-effect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-label@2.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-popper@1.2.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@floating-ui/react-dom': 2.1.2(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-arrow': 1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-context': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-layout-effect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-rect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-size': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/rect': 1.1.0 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-portal@1.1.2(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-layout-effect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-primitive@2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-slot': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-select@2.1.2(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/number': 1.1.0 | ||||
|       '@radix-ui/primitive': 1.1.0 | ||||
|       '@radix-ui/react-collection': 1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-context': 1.1.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-direction': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-dismissable-layer': 1.1.1(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-focus-guards': 1.1.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-focus-scope': 1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-id': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-popper': 1.2.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-portal': 1.1.2(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-slot': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-controllable-state': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-layout-effect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-use-previous': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       '@radix-ui/react-visually-hidden': 1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       aria-hidden: 1.2.4 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|       react-remove-scroll: 2.6.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/react-slot@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-compose-refs': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-callback-ref@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-controllable-state@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-escape-keydown@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-use-callback-ref': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-layout-effect@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-previous@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-rect@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/rect': 1.1.0 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-use-size@1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-use-layout-effect': 1.1.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   '@radix-ui/react-visually-hidden@1.1.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106)': | ||||
|     dependencies: | ||||
|       '@radix-ui/react-primitive': 2.0.0(@types/react-dom@18.3.1)(@types/react@18.3.12)(react-dom@19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106))(react@19.0.0-rc-66855b96-20241106) | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-dom: 19.0.0-rc-66855b96-20241106(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
|       '@types/react-dom': 18.3.1 | ||||
| 
 | ||||
|   '@radix-ui/rect@1.1.0': {} | ||||
| 
 | ||||
|   '@rtsao/scc@1.1.0': {} | ||||
| 
 | ||||
|   '@rushstack/eslint-patch@1.10.4': {} | ||||
| @ -1984,6 +2641,10 @@ snapshots: | ||||
| 
 | ||||
|   argparse@2.0.1: {} | ||||
| 
 | ||||
|   aria-hidden@1.2.4: | ||||
|     dependencies: | ||||
|       tslib: 2.8.1 | ||||
| 
 | ||||
|   aria-query@5.3.2: {} | ||||
| 
 | ||||
|   array-buffer-byte-length@1.0.1: | ||||
| @ -2113,8 +2774,14 @@ snapshots: | ||||
|     optionalDependencies: | ||||
|       fsevents: 2.3.3 | ||||
| 
 | ||||
|   class-variance-authority@0.7.1: | ||||
|     dependencies: | ||||
|       clsx: 2.1.1 | ||||
| 
 | ||||
|   client-only@0.0.1: {} | ||||
| 
 | ||||
|   clsx@2.1.1: {} | ||||
| 
 | ||||
|   color-convert@2.0.1: | ||||
|     dependencies: | ||||
|       color-name: 1.1.4 | ||||
| @ -2192,6 +2859,8 @@ snapshots: | ||||
|   detect-libc@2.0.3: | ||||
|     optional: true | ||||
| 
 | ||||
|   detect-node-es@1.1.0: {} | ||||
| 
 | ||||
|   didyoumean@1.2.2: {} | ||||
| 
 | ||||
|   dlv@1.1.3: {} | ||||
| @ -2318,8 +2987,8 @@ snapshots: | ||||
|       '@typescript-eslint/parser': 8.16.0(eslint@8.57.1)(typescript@5.7.2) | ||||
|       eslint: 8.57.1 | ||||
|       eslint-import-resolver-node: 0.3.9 | ||||
|       eslint-import-resolver-typescript: 3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0)(eslint@8.57.1) | ||||
|       eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1) | ||||
|       eslint-import-resolver-typescript: 3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1) | ||||
|       eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1) | ||||
|       eslint-plugin-jsx-a11y: 6.10.2(eslint@8.57.1) | ||||
|       eslint-plugin-react: 7.37.2(eslint@8.57.1) | ||||
|       eslint-plugin-react-hooks: 5.0.0(eslint@8.57.1) | ||||
| @ -2338,37 +3007,37 @@ snapshots: | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| 
 | ||||
|   eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0)(eslint@8.57.1): | ||||
|   eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1): | ||||
|     dependencies: | ||||
|       '@nolyfill/is-core-module': 1.0.39 | ||||
|       debug: 4.3.7 | ||||
|       enhanced-resolve: 5.17.1 | ||||
|       eslint: 8.57.1 | ||||
|       eslint-module-utils: 2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1) | ||||
|       eslint-module-utils: 2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1) | ||||
|       fast-glob: 3.3.2 | ||||
|       get-tsconfig: 4.8.1 | ||||
|       is-bun-module: 1.3.0 | ||||
|       is-glob: 4.0.3 | ||||
|     optionalDependencies: | ||||
|       eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1) | ||||
|       eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1) | ||||
|     transitivePeerDependencies: | ||||
|       - '@typescript-eslint/parser' | ||||
|       - eslint-import-resolver-node | ||||
|       - eslint-import-resolver-webpack | ||||
|       - supports-color | ||||
| 
 | ||||
|   eslint-module-utils@2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1): | ||||
|   eslint-module-utils@2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1): | ||||
|     dependencies: | ||||
|       debug: 3.2.7 | ||||
|     optionalDependencies: | ||||
|       '@typescript-eslint/parser': 8.16.0(eslint@8.57.1)(typescript@5.7.2) | ||||
|       eslint: 8.57.1 | ||||
|       eslint-import-resolver-node: 0.3.9 | ||||
|       eslint-import-resolver-typescript: 3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0)(eslint@8.57.1) | ||||
|       eslint-import-resolver-typescript: 3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| 
 | ||||
|   eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1): | ||||
|   eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1): | ||||
|     dependencies: | ||||
|       '@rtsao/scc': 1.1.0 | ||||
|       array-includes: 3.1.8 | ||||
| @ -2379,7 +3048,7 @@ snapshots: | ||||
|       doctrine: 2.1.0 | ||||
|       eslint: 8.57.1 | ||||
|       eslint-import-resolver-node: 0.3.9 | ||||
|       eslint-module-utils: 2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3)(eslint@8.57.1) | ||||
|       eslint-module-utils: 2.12.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.3(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.16.0(eslint@8.57.1)(typescript@5.7.2))(eslint@8.57.1))(eslint@8.57.1))(eslint@8.57.1) | ||||
|       hasown: 2.0.2 | ||||
|       is-core-module: 2.15.1 | ||||
|       is-glob: 4.0.3 | ||||
| @ -2592,6 +3261,8 @@ snapshots: | ||||
|       has-symbols: 1.0.3 | ||||
|       hasown: 2.0.2 | ||||
| 
 | ||||
|   get-nonce@1.0.1: {} | ||||
| 
 | ||||
|   get-symbol-description@1.0.2: | ||||
|     dependencies: | ||||
|       call-bind: 1.0.7 | ||||
| @ -2687,6 +3358,10 @@ snapshots: | ||||
|       hasown: 2.0.2 | ||||
|       side-channel: 1.0.6 | ||||
| 
 | ||||
|   invariant@2.2.4: | ||||
|     dependencies: | ||||
|       loose-envify: 1.4.0 | ||||
| 
 | ||||
|   is-array-buffer@3.0.4: | ||||
|     dependencies: | ||||
|       call-bind: 1.0.7 | ||||
| @ -2868,6 +3543,10 @@ snapshots: | ||||
| 
 | ||||
|   lru-cache@10.4.3: {} | ||||
| 
 | ||||
|   lucide-react@0.462.0(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
| 
 | ||||
|   merge2@1.4.1: {} | ||||
| 
 | ||||
|   micromatch@4.0.8: | ||||
| @ -3076,8 +3755,40 @@ snapshots: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       scheduler: 0.25.0-rc-66855b96-20241106 | ||||
| 
 | ||||
|   react-hook-form@7.53.2(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
| 
 | ||||
|   react-is@16.13.1: {} | ||||
| 
 | ||||
|   react-remove-scroll-bar@2.3.6(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-style-singleton: 2.2.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       tslib: 2.8.1 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   react-remove-scroll@2.6.0(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       react-remove-scroll-bar: 2.3.6(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       react-style-singleton: 2.2.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       tslib: 2.8.1 | ||||
|       use-callback-ref: 1.3.2(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|       use-sidecar: 1.1.2(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106) | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   react-style-singleton@2.2.1(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       get-nonce: 1.0.1 | ||||
|       invariant: 2.2.4 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       tslib: 2.8.1 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   react@19.0.0-rc-66855b96-20241106: {} | ||||
| 
 | ||||
|   read-cache@1.0.0: | ||||
| @ -3307,6 +4018,12 @@ snapshots: | ||||
| 
 | ||||
|   supports-preserve-symlinks-flag@1.0.0: {} | ||||
| 
 | ||||
|   tailwind-merge@2.5.5: {} | ||||
| 
 | ||||
|   tailwindcss-animate@1.0.7(tailwindcss@3.4.15): | ||||
|     dependencies: | ||||
|       tailwindcss: 3.4.15 | ||||
| 
 | ||||
|   tailwindcss@3.4.15: | ||||
|     dependencies: | ||||
|       '@alloc/quick-lru': 5.2.0 | ||||
| @ -3419,6 +4136,21 @@ snapshots: | ||||
|     dependencies: | ||||
|       punycode: 2.3.1 | ||||
| 
 | ||||
|   use-callback-ref@1.3.2(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       tslib: 2.8.1 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   use-sidecar@1.1.2(@types/react@18.3.12)(react@19.0.0-rc-66855b96-20241106): | ||||
|     dependencies: | ||||
|       detect-node-es: 1.1.0 | ||||
|       react: 19.0.0-rc-66855b96-20241106 | ||||
|       tslib: 2.8.1 | ||||
|     optionalDependencies: | ||||
|       '@types/react': 18.3.12 | ||||
| 
 | ||||
|   util-deprecate@1.0.2: {} | ||||
| 
 | ||||
|   which-boxed-primitive@1.0.2: | ||||
| @ -3483,3 +4215,5 @@ snapshots: | ||||
|   yaml@2.6.1: {} | ||||
| 
 | ||||
|   yocto-queue@0.1.0: {} | ||||
| 
 | ||||
|   zod@3.23.8: {} | ||||
|  | ||||
							
								
								
									
										
											BIN
										
									
								
								public/me.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/me.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 159 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/me.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/me.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.3 MiB | 
							
								
								
									
										
											BIN
										
									
								
								public/vico.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/vico.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 406 KiB | 
							
								
								
									
										22
									
								
								src/app.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/app.config.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| type AppConfig = { | ||||
|   navigator: { label: string; path: string }[]; | ||||
| }; | ||||
| 
 | ||||
| export const appConfig: AppConfig = { | ||||
|   navigator: [ | ||||
|     { | ||||
|       label: "Home", | ||||
|       path: "/", | ||||
|     }, | ||||
|     { | ||||
|       label: "Projects", | ||||
|       path: "/#projects", | ||||
|     }, | ||||
|     { | ||||
|       label: "Contact", | ||||
|       path: "/contact/#", | ||||
|     }, | ||||
|   ], | ||||
| }; | ||||
| 
 | ||||
| export const appNavigator = appConfig.navigator; | ||||
							
								
								
									
										21
									
								
								src/app/(__PAGES__)/contact/page.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/app/(__PAGES__)/contact/page.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| import MeCard from "@/components/me-card"; | ||||
| import Contact from "@/components/setions/contact"; | ||||
| import React from "react"; | ||||
| 
 | ||||
| function ContactPage() { | ||||
|   return ( | ||||
|     <div className="flex gap-12 lg:gap-20 container "> | ||||
|       <MeCard | ||||
|         className="sticky top-20" | ||||
|         button={{ | ||||
|           label: "Email Me", | ||||
|           link: `mailto:${process.env.NEXT_PUBLIC_EMAIL}`, | ||||
|         }} | ||||
|       /> | ||||
| 
 | ||||
|       <Contact /> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default ContactPage; | ||||
							
								
								
									
										18
									
								
								src/app/(__PAGES__)/layout.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								src/app/(__PAGES__)/layout.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | ||||
| import React from "react"; | ||||
| 
 | ||||
| import Navbar from "@/components/navbar"; | ||||
| 
 | ||||
| function Layout({ children }: { children: JSX.Element }) { | ||||
|   return ( | ||||
|     <div className="space-y-4 "> | ||||
|       <Navbar /> | ||||
|       <main className="container min-h-screen"> | ||||
|         {children} | ||||
| 
 | ||||
|         {/* <div className="absolute w-1 h-screen top-0 left-1/2 -translate-x-1/2 transform bg-foreground" /> */} | ||||
|       </main> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Layout; | ||||
							
								
								
									
										17
									
								
								src/app/(__PAGES__)/page.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/app/(__PAGES__)/page.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| import { Hero, Projects } from "@/components/setions"; | ||||
| import { Button } from "@/components/ui/button"; | ||||
| import { projects } from "@/constants"; | ||||
| import { ArrowRight } from "lucide-react"; | ||||
| import Image from "next/image"; | ||||
| import Link from "next/link"; | ||||
| 
 | ||||
| export default function Home() { | ||||
|   return ( | ||||
|     <> | ||||
|       <Hero /> | ||||
|       <div className="w-full mt-64"> | ||||
|         <Projects /> | ||||
|       </div> | ||||
|     </> | ||||
|   ); | ||||
| } | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Black.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Black.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Bold.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Bold.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-ExtraBold.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-ExtraBold.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-ExtraLight.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-ExtraLight.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Italic.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Italic.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Light.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Light.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Medium.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Medium.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Regular.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/app/fonts/Poppins-Regular.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -2,20 +2,127 @@ | ||||
| @tailwind components; | ||||
| @tailwind utilities; | ||||
| 
 | ||||
| :root { | ||||
|   --background: #ffffff; | ||||
|   --foreground: #171717; | ||||
| } | ||||
| 
 | ||||
| @media (prefers-color-scheme: dark) { | ||||
|   :root { | ||||
|     --background: #0a0a0a; | ||||
|     --foreground: #ededed; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| body { | ||||
|   color: var(--foreground); | ||||
|   background: var(--background); | ||||
|   font-family: Arial, Helvetica, sans-serif; | ||||
| } | ||||
| 
 | ||||
| @layer base { | ||||
|   :root { | ||||
|     --background: 0 0% 100%; | ||||
|     --foreground: 240 10% 3.9%; | ||||
|     --card: 0 0% 100%; | ||||
|     --card-foreground: 240 10% 3.9%; | ||||
|     --popover: 0 0% 100%; | ||||
|     --popover-foreground: 240 10% 3.9%; | ||||
|     --primary: 240 5.9% 10%; | ||||
|     --primary-foreground: 0 0% 98%; | ||||
|     --secondary: 240 4.8% 95.9%; | ||||
|     --secondary-foreground: 240 5.9% 10%; | ||||
|     --muted: 240 4.8% 95.9%; | ||||
|     --muted-foreground: 240 3.8% 46.1%; | ||||
|     --accent: 240 4.8% 95.9%; | ||||
|     --accent-foreground: 240 5.9% 10%; | ||||
|     --destructive: 0 84.2% 60.2%; | ||||
|     --destructive-foreground: 0 0% 98%; | ||||
|     --border: 240 5.9% 90%; | ||||
|     --input: 240 5.9% 90%; | ||||
|     --ring: 240 10% 3.9%; | ||||
|     --chart-1: 12 76% 61%; | ||||
|     --chart-2: 173 58% 39%; | ||||
|     --chart-3: 197 37% 24%; | ||||
|     --chart-4: 43 74% 66%; | ||||
|     --chart-5: 27 87% 67%; | ||||
| 
 | ||||
|     /* Border Radius */ | ||||
|     --radius: 0.5rem; | ||||
|   } | ||||
|   .dark { | ||||
|     --background: 20 8% 8%; | ||||
|     --foreground: 0 0% 100%; | ||||
|     --card: 240 10% 3.9%; | ||||
|     --card-foreground: 0 0% 98%; | ||||
|     --popover: 240 10% 3.9%; | ||||
|     --popover-foreground: 0 0% 98%; | ||||
|     --primary: 17 90% 59%; | ||||
|     --primary-foreground: 0 0% 98%; | ||||
|     --secondary: 240 3.7% 15.9%; | ||||
|     --secondary-foreground: 0 0% 98%; | ||||
|     --muted: 20 6% 10%; | ||||
|     --muted-foreground: 0 5% 58%; | ||||
|     --accent: 240 3.7% 15.9%; | ||||
|     --accent-foreground: 0 0% 98%; | ||||
|     --destructive: 0 62.8% 30.6%; | ||||
|     --destructive-foreground: 0 0% 98%; | ||||
|     --border: 240 3.7% 15.9%; | ||||
|     --input: 240 3.7% 15.9%; | ||||
|     --ring: 240 4.9% 83.9%; | ||||
|     --chart-1: 220 70% 50%; | ||||
|     --chart-2: 160 60% 45%; | ||||
|     --chart-3: 30 80% 55%; | ||||
|     --chart-4: 280 65% 60%; | ||||
|     --chart-5: 340 75% 55%; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @layer base { | ||||
|   * { | ||||
|     @apply border-border; | ||||
|   } | ||||
|   body { | ||||
|     @apply dark bg-background text-foreground; | ||||
|   } | ||||
| 
 | ||||
|   @font-face { | ||||
|     font-family: "Poppins"; | ||||
|     src: url("./fonts/Poppins-Regular.ttf") format("truetype"); | ||||
|     font-weight: 400; | ||||
|     font-style: normal; | ||||
|   } | ||||
| 
 | ||||
|   @font-face { | ||||
|     font-family: "Poppins"; | ||||
|     src: url("./fonts/Poppins-Bold.ttf") format("truetype"); | ||||
|     font-weight: 700; | ||||
|     font-style: normal; | ||||
|   } | ||||
| 
 | ||||
|   .halftone { | ||||
|     --dotSize: 0.25rem; | ||||
|     --stop1: 3%; | ||||
|     --stop2: 60%; | ||||
|   } | ||||
| 
 | ||||
|   .halftone::after { | ||||
|     /* Cover our element */ | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     inset: 0; | ||||
| 
 | ||||
|     /* Dotted background */ | ||||
|     background-image: radial-gradient( | ||||
|       circle at center, | ||||
|       hsl(var(--foreground)) var(--dotSize), | ||||
|       transparent 0 | ||||
|     ); | ||||
|     background-size: 2rem 2rem; | ||||
|     background-position: 0 0, 0.65rem 0.65rem; | ||||
|   } | ||||
|   .halftone::after { | ||||
|     mask-image: linear-gradient( | ||||
|       hsl(var(--background) / 0), | ||||
|       hsl(var(--background) / 0.25), | ||||
|       hsl(var(--background) / 0) | ||||
|     ); | ||||
|   } | ||||
|   .hero-figure-gradient { | ||||
|     background: linear-gradient( | ||||
|       hsl(var(--background) / 0.95), | ||||
|       1%, | ||||
|       hsl(var(--background)) | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| html { | ||||
|   scroll-behavior: smooth; | ||||
| } | ||||
|  | ||||
| @ -1,18 +1,6 @@ | ||||
| import type { Metadata } from "next"; | ||||
| import localFont from "next/font/local"; | ||||
| import "./globals.css"; | ||||
| 
 | ||||
| const geistSans = localFont({ | ||||
|   src: "./fonts/GeistVF.woff", | ||||
|   variable: "--font-geist-sans", | ||||
|   weight: "100 900", | ||||
| }); | ||||
| const geistMono = localFont({ | ||||
|   src: "./fonts/GeistMonoVF.woff", | ||||
|   variable: "--font-geist-mono", | ||||
|   weight: "100 900", | ||||
| }); | ||||
| 
 | ||||
| export const metadata: Metadata = { | ||||
|   title: "Create Next App", | ||||
|   description: "Generated by create next app", | ||||
| @ -25,9 +13,7 @@ export default function RootLayout({ | ||||
| }>) { | ||||
|   return ( | ||||
|     <html lang="en"> | ||||
|       <body | ||||
|         className={`${geistSans.variable} ${geistMono.variable} antialiased`} | ||||
|       > | ||||
|       <body suppressHydrationWarning className={"font-display antialiased"}> | ||||
|         {children} | ||||
|       </body> | ||||
|     </html> | ||||
|  | ||||
							
								
								
									
										101
									
								
								src/app/page.tsx
									
									
									
									
									
								
							
							
						
						
									
										101
									
								
								src/app/page.tsx
									
									
									
									
									
								
							| @ -1,101 +0,0 @@ | ||||
| import Image from "next/image"; | ||||
| 
 | ||||
| export default function Home() { | ||||
|   return ( | ||||
|     <div className="grid grid-rows-[20px_1fr_20px] items-center justify-items-center min-h-screen p-8 pb-20 gap-16 sm:p-20 font-[family-name:var(--font-geist-sans)]"> | ||||
|       <main className="flex flex-col gap-8 row-start-2 items-center sm:items-start"> | ||||
|         <Image | ||||
|           className="dark:invert" | ||||
|           src="/next.svg" | ||||
|           alt="Next.js logo" | ||||
|           width={180} | ||||
|           height={38} | ||||
|           priority | ||||
|         /> | ||||
|         <ol className="list-inside list-decimal text-sm text-center sm:text-left font-[family-name:var(--font-geist-mono)]"> | ||||
|           <li className="mb-2"> | ||||
|             Get started by editing{" "} | ||||
|             <code className="bg-black/[.05] dark:bg-white/[.06] px-1 py-0.5 rounded font-semibold"> | ||||
|               src/app/page.tsx | ||||
|             </code> | ||||
|             . | ||||
|           </li> | ||||
|           <li>Save and see your changes instantly.</li> | ||||
|         </ol> | ||||
| 
 | ||||
|         <div className="flex gap-4 items-center flex-col sm:flex-row"> | ||||
|           <a | ||||
|             className="rounded-full border border-solid border-transparent transition-colors flex items-center justify-center bg-foreground text-background gap-2 hover:bg-[#383838] dark:hover:bg-[#ccc] text-sm sm:text-base h-10 sm:h-12 px-4 sm:px-5" | ||||
|             href="https://vercel.com/new?utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app" | ||||
|             target="_blank" | ||||
|             rel="noopener noreferrer" | ||||
|           > | ||||
|             <Image | ||||
|               className="dark:invert" | ||||
|               src="/vercel.svg" | ||||
|               alt="Vercel logomark" | ||||
|               width={20} | ||||
|               height={20} | ||||
|             /> | ||||
|             Deploy now | ||||
|           </a> | ||||
|           <a | ||||
|             className="rounded-full border border-solid border-black/[.08] dark:border-white/[.145] transition-colors flex items-center justify-center hover:bg-[#f2f2f2] dark:hover:bg-[#1a1a1a] hover:border-transparent text-sm sm:text-base h-10 sm:h-12 px-4 sm:px-5 sm:min-w-44" | ||||
|             href="https://nextjs.org/docs?utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app" | ||||
|             target="_blank" | ||||
|             rel="noopener noreferrer" | ||||
|           > | ||||
|             Read our docs | ||||
|           </a> | ||||
|         </div> | ||||
|       </main> | ||||
|       <footer className="row-start-3 flex gap-6 flex-wrap items-center justify-center"> | ||||
|         <a | ||||
|           className="flex items-center gap-2 hover:underline hover:underline-offset-4" | ||||
|           href="https://nextjs.org/learn?utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app" | ||||
|           target="_blank" | ||||
|           rel="noopener noreferrer" | ||||
|         > | ||||
|           <Image | ||||
|             aria-hidden | ||||
|             src="/file.svg" | ||||
|             alt="File icon" | ||||
|             width={16} | ||||
|             height={16} | ||||
|           /> | ||||
|           Learn | ||||
|         </a> | ||||
|         <a | ||||
|           className="flex items-center gap-2 hover:underline hover:underline-offset-4" | ||||
|           href="https://vercel.com/templates?framework=next.js&utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app" | ||||
|           target="_blank" | ||||
|           rel="noopener noreferrer" | ||||
|         > | ||||
|           <Image | ||||
|             aria-hidden | ||||
|             src="/window.svg" | ||||
|             alt="Window icon" | ||||
|             width={16} | ||||
|             height={16} | ||||
|           /> | ||||
|           Examples | ||||
|         </a> | ||||
|         <a | ||||
|           className="flex items-center gap-2 hover:underline hover:underline-offset-4" | ||||
|           href="https://nextjs.org?utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app" | ||||
|           target="_blank" | ||||
|           rel="noopener noreferrer" | ||||
|         > | ||||
|           <Image | ||||
|             aria-hidden | ||||
|             src="/globe.svg" | ||||
|             alt="Globe icon" | ||||
|             width={16} | ||||
|             height={16} | ||||
|           /> | ||||
|           Go to nextjs.org → | ||||
|         </a> | ||||
|       </footer> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
							
								
								
									
										13
									
								
								src/components/heading.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/components/heading.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | ||||
| import React from "react"; | ||||
| 
 | ||||
| function Heading({ title, subTitle }: { title: string; subTitle?: string }) { | ||||
|   return ( | ||||
|     <h2 className="text-8xl pb-4 font-black  order-last sticky top-0 z-50 bg-background"> | ||||
|       <span className="text-muted-foreground">{subTitle}</span> | ||||
|       <br /> | ||||
|       {title} | ||||
|     </h2> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Heading; | ||||
							
								
								
									
										53
									
								
								src/components/me-card.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/components/me-card.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| import React from "react"; | ||||
| import { Button } from "./ui/button"; | ||||
| import Image from "next/image"; | ||||
| import { cn } from "@/lib/utils"; | ||||
| import Link from "next/link"; | ||||
| 
 | ||||
| function MeCard({ | ||||
|   className, | ||||
|   button, | ||||
| }: { | ||||
|   button: { label: string; link: string }; | ||||
|   className?: string; | ||||
| }) { | ||||
|   return ( | ||||
|     <div | ||||
|       className={cn( | ||||
|         `group overflow-hidden w-full max-w-xs h-[80vh] bg-muted 
 | ||||
|                       rounded-xl space-y-8 p-4 flex flex-col  | ||||
|                       justify-between pb-20 relative`,
 | ||||
|         className | ||||
|       )} | ||||
|     > | ||||
|       <div className="space-y-4"> | ||||
|         <div className="h-64 w-3/4 mx-auto relative rounded-xl overflow-hidden z-10"> | ||||
|           <Image | ||||
|             src="/me.jpg" | ||||
|             alt="me" | ||||
|             fill | ||||
|             className="object-cover scale-105 transition-all duration-300 group-hover:scale-100" | ||||
|           /> | ||||
|         </div> | ||||
| 
 | ||||
|         <div className="text-center flex flex-col items-center"> | ||||
|           <h4 className="text-lg  font-bold translate-y-px  ">Pablo</h4> | ||||
|           <span className="text-emerald-500 text-sm -translate-y-px"> | ||||
|             Available for work | ||||
|           </span> | ||||
|           <Button className="mt-4" asChild> | ||||
|             <Link href={button.link}>{button.label}</Link> | ||||
|           </Button> | ||||
|         </div> | ||||
|       </div> | ||||
| 
 | ||||
|       <p className="text-center text-muted-foreground text-lg font-bold"> | ||||
|         A Software Engineer who has developed countless innovative solutions. | ||||
|       </p> | ||||
| 
 | ||||
|       <div className="w-full h-40 halftone absolute left-0 group-hover:scale-[102.5%] transition-all duration-300 top-0 z-0" /> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default MeCard; | ||||
							
								
								
									
										26
									
								
								src/components/navbar.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/components/navbar.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| import React from "react"; | ||||
| import { Button } from "@/ui/button"; | ||||
| import Link from "next/link"; | ||||
| import NavigationBreadcrumbs from "./navigation-breadcrumbs"; | ||||
| 
 | ||||
| function Navbar() { | ||||
|   return ( | ||||
|     <nav className="container py-4 flex justify-between items-center "> | ||||
|       <div className="flex items-center gap-4"> | ||||
|         <Link | ||||
|           className="text-sm" | ||||
|           href={`mailto:${process.env.NEXT_PUBLIC_EMAIL}`} | ||||
|         > | ||||
|           {process.env.NEXT_PUBLIC_EMAIL} | ||||
|         </Link> | ||||
|         <Button asChild size={"sm"}> | ||||
|           <Link href={"/contact"}>Work with me</Link> | ||||
|         </Button> | ||||
|       </div> | ||||
| 
 | ||||
|       <NavigationBreadcrumbs /> | ||||
|     </nav> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Navbar; | ||||
							
								
								
									
										44
									
								
								src/components/navigation-breadcrumbs.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/components/navigation-breadcrumbs.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | ||||
| "use client"; | ||||
| import { usePathname } from "next/navigation"; | ||||
| import React from "react"; | ||||
| import { | ||||
|   Breadcrumb, | ||||
|   BreadcrumbItem, | ||||
|   BreadcrumbLink, | ||||
|   BreadcrumbList, | ||||
|   BreadcrumbSeparator, | ||||
| } from "@/components/ui/breadcrumb"; | ||||
| import { appNavigator } from "@/app.config"; | ||||
| import { cn } from "@/lib/utils"; | ||||
| 
 | ||||
| function NavigationBreadcrumbs() { | ||||
|   const pathname = usePathname(); | ||||
|   return ( | ||||
|     <Breadcrumb> | ||||
|       <BreadcrumbList> | ||||
|         {appNavigator.map(({ label, path }, idx) => ( | ||||
|           <div key={path} className="flex items-center gap-2"> | ||||
|             <BreadcrumbItem> | ||||
|               <BreadcrumbLink | ||||
|                 className={cn( | ||||
|                   pathname === path.replace(/\/#/g, "") && "text-foreground" | ||||
|                 )} | ||||
|                 href={path} | ||||
|               > | ||||
|                 {" "} | ||||
|                 {label} | ||||
|               </BreadcrumbLink> | ||||
|             </BreadcrumbItem> | ||||
|             {idx + 1 < appNavigator.length && ( | ||||
|               <BreadcrumbSeparator> | ||||
|                 <span>/</span> | ||||
|               </BreadcrumbSeparator> | ||||
|             )} | ||||
|           </div> | ||||
|         ))} | ||||
|       </BreadcrumbList> | ||||
|     </Breadcrumb> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default NavigationBreadcrumbs; | ||||
							
								
								
									
										129
									
								
								src/components/setions/contact.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								src/components/setions/contact.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,129 @@ | ||||
| "use client"; | ||||
| import React from "react"; | ||||
| import Heading from "../heading"; | ||||
| import { z } from "zod"; | ||||
| import { zodResolver } from "@hookform/resolvers/zod"; | ||||
| import { useForm } from "react-hook-form"; | ||||
| import { Button } from "@/ui/button"; | ||||
| import { Textarea } from "@/ui/textarea"; | ||||
| import { | ||||
|   Form, | ||||
|   FormControl, | ||||
|   FormField, | ||||
|   FormItem, | ||||
|   FormLabel, | ||||
|   FormMessage, | ||||
| } from "@/ui/form"; | ||||
| import { Input } from "@/ui/input"; | ||||
| import { | ||||
|   Select, | ||||
|   SelectContent, | ||||
|   SelectItem, | ||||
|   SelectTrigger, | ||||
|   SelectValue, | ||||
| } from "@/components/ui/select"; | ||||
| 
 | ||||
| const formSchema = z.object({ | ||||
|   name: z.string().min(2).max(50), | ||||
|   email: z.string().email(), | ||||
|   budget: z.string(), | ||||
|   message: z.string().max(500), | ||||
| }); | ||||
| 
 | ||||
| function Contact() { | ||||
|   // 1. Define your form.
 | ||||
|   const form = useForm<z.infer<typeof formSchema>>({ | ||||
|     resolver: zodResolver(formSchema), | ||||
|   }); | ||||
| 
 | ||||
|   // 2. Define a submit handler.
 | ||||
|   function onSubmit(values: z.infer<typeof formSchema>) { | ||||
|     // Do something with the form values.
 | ||||
|     // ✅ This will be type-safe and validated.
 | ||||
|     console.log(values); | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <div className="w-full"> | ||||
|       <Heading subTitle="Let's Work" title="Together" /> | ||||
|       <Form {...form}> | ||||
|         <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-8"> | ||||
|           <div className="flex gap-4 w-full"> | ||||
|             <FormField | ||||
|               control={form.control} | ||||
|               name="name" | ||||
|               render={({ field }) => ( | ||||
|                 <FormItem className="w-full "> | ||||
|                   <FormLabel>Name</FormLabel> | ||||
|                   <FormControl> | ||||
|                     <Input placeholder="John Doe" {...field} /> | ||||
|                   </FormControl> | ||||
|                   <FormMessage /> | ||||
|                 </FormItem> | ||||
|               )} | ||||
|             /> | ||||
|             <FormField | ||||
|               control={form.control} | ||||
|               name="email" | ||||
|               render={({ field }) => ( | ||||
|                 <FormItem className="w-full"> | ||||
|                   <FormLabel>Email</FormLabel> | ||||
|                   <FormControl> | ||||
|                     <Input placeholder="email@example.com" {...field} /> | ||||
|                   </FormControl> | ||||
|                   <FormMessage /> | ||||
|                 </FormItem> | ||||
|               )} | ||||
|             /> | ||||
|           </div> | ||||
|           <FormField | ||||
|             control={form.control} | ||||
|             name="budget" | ||||
|             render={({ field }) => ( | ||||
|               <FormItem> | ||||
|                 <FormLabel>Budget</FormLabel> | ||||
|                 <FormControl> | ||||
|                   <Select | ||||
|                     onValueChange={field.onChange} | ||||
|                     defaultValue={field.value} | ||||
|                   > | ||||
|                     <SelectTrigger className="w-full"> | ||||
|                       <SelectValue | ||||
|                         className="placeholder:text-muted-foreground" | ||||
|                         placeholder="Select your Budget" | ||||
|                       /> | ||||
|                     </SelectTrigger> | ||||
|                     <SelectContent> | ||||
|                       <SelectItem value="light">{"< €2k"}</SelectItem> | ||||
|                       <SelectItem value="dark">Dark</SelectItem> | ||||
|                       <SelectItem value="system">System</SelectItem> | ||||
|                     </SelectContent> | ||||
|                   </Select> | ||||
|                 </FormControl> | ||||
|                 <FormMessage /> | ||||
|               </FormItem> | ||||
|             )} | ||||
|           /> | ||||
|           <FormField | ||||
|             control={form.control} | ||||
|             name="message" | ||||
|             render={({ field }) => ( | ||||
|               <FormItem> | ||||
|                 <FormLabel>Message</FormLabel> | ||||
|                 <FormControl> | ||||
|                   <Textarea rows={4} placeholder="Message..." {...field} /> | ||||
|                 </FormControl> | ||||
|                 <FormMessage /> | ||||
|               </FormItem> | ||||
|             )} | ||||
|           /> | ||||
|           <Button type="submit" className="w-full"> | ||||
|             Submit | ||||
|           </Button> | ||||
|         </form> | ||||
|       </Form> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Contact; | ||||
							
								
								
									
										7
									
								
								src/components/setions/cv.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/components/setions/cv.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| import React from "react"; | ||||
| 
 | ||||
| function CV() { | ||||
|   return <div>CV</div>; | ||||
| } | ||||
| 
 | ||||
| export default CV; | ||||
							
								
								
									
										87
									
								
								src/components/setions/hero.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								src/components/setions/hero.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,87 @@ | ||||
| "use client"; | ||||
| 
 | ||||
| import { cn } from "@/lib/utils"; | ||||
| import Image from "next/image"; | ||||
| import React from "react"; | ||||
| 
 | ||||
| function Hero() { | ||||
|   const [hovered, setHovered] = React.useState(""); | ||||
| 
 | ||||
|   const textHover = | ||||
|     "hover:text-primary hover:scale-105 transition-all duration-150"; | ||||
|   return ( | ||||
|     <div className="text-7xl rounded-md group font-bold max-w-xl mx-auto text-center  flex flex-col relative cursor-default  translate-x-16"> | ||||
|       <span | ||||
|         className={cn(textHover)} | ||||
|         onMouseEnter={() => setHovered("text-1")} | ||||
|         onMouseLeave={() => setHovered("")} | ||||
|       > | ||||
|         Creative | ||||
|       </span> | ||||
|       <div className="flex gap-4 justify-center items-center"> | ||||
|         <div | ||||
|           className={ | ||||
|             "relative size-20 overflow-hidden rounded-full transition-all duration-150" | ||||
|           } | ||||
|         > | ||||
|           <Image | ||||
|             src={"/me.jpg"} | ||||
|             alt="me" | ||||
|             width={180} | ||||
|             height={420} | ||||
|             // style={{ objectPosition: "0 -1rem " }}
 | ||||
|             className="object-cover group-hover:object-center transition-all -z-20 duration-300 absolute" | ||||
|           /> | ||||
|           {/* <div className="w-full h-60 -bottom-40 absolute hero-figure-gradient -z-10 group-hover:translate-y-40 transition-all duration-500 ease-in-out" /> */} | ||||
|         </div> | ||||
|         <span | ||||
|           className={cn(textHover)} | ||||
|           onMouseEnter={() => setHovered("text-2")} | ||||
|           onMouseLeave={() => setHovered("")} | ||||
|         > | ||||
|           Timeless | ||||
|         </span> | ||||
|       </div> | ||||
|       <span | ||||
|         onMouseEnter={() => setHovered("text-3")} | ||||
|         onMouseLeave={() => setHovered("")} | ||||
|         className={cn( | ||||
|           `absolute left-0 top-full ${textHover}`, | ||||
|           hovered.length ? "text-foreground" : "text-primary" | ||||
|         )} | ||||
|       > | ||||
|         Unique | ||||
|       </span> | ||||
| 
 | ||||
|       <svg | ||||
|         className="size-20 absolute top-2/3 -translate-y-2/3 transform -left-4 text-muted-foreground group-hover:text-popover-foreground transition-all duration-300" | ||||
|         viewBox="0 0 284 201" | ||||
|         fill="none" | ||||
|         xmlns="http://www.w3.org/2000/svg" | ||||
|       > | ||||
|         <g clipPath="url(#clip0_102_3)"> | ||||
|           <path | ||||
|             d="M95.2362 104.356C95.1418 97.0072 99.5149 92.501 104.083 88.8727C110.504 83.9101 117.525 79.5812 124.742 76.1301C158.402 61.1033 192.787 61.1147 227.086 73.8886C235.794 77.1673 244.177 81.7469 253.617 86.2445C254.06 76.4732 248.408 67.5999 248.315 57.4875C252.458 58.8669 253.643 62.134 254.698 64.8159C258.984 75.8362 263.155 87.0353 267.034 98.2996C268.852 103.729 267.73 106.282 262.464 107.456C251.527 110.047 240.867 109.046 230.778 104.386C230.42 104.159 230.226 103.281 229.788 101.997C236.648 95.5545 245.338 103.597 253.124 99.2512C242.615 88.5437 229.454 83.1866 215.968 79.1305C201.833 74.9121 187.55 72.1082 172.811 72.7839C158.364 73.3943 144.745 77.0445 131.093 81.9303C117.376 86.5234 105.722 94.1881 95.2362 104.356Z" | ||||
|             fill="currentColor" | ||||
|           /> | ||||
|         </g> | ||||
|         <path | ||||
|           d="M6.29 130.2H27.232C33.5467 130.2 38.2087 131.557 41.218 134.27C44.2273 136.934 45.732 141.078 45.732 146.702C45.732 152.326 44.2273 156.495 41.218 159.208C38.2087 161.872 33.5467 163.204 27.232 163.204H16.724V182H6.29V130.2ZM27.528 155.064C29.7973 155.064 31.6473 154.373 33.078 152.992C34.558 151.611 35.298 149.514 35.298 146.702C35.298 143.89 34.558 141.793 33.078 140.412C31.6473 139.031 29.7973 138.34 27.528 138.34H16.724V155.064H27.528ZM80.2281 171.27C80.2281 172.602 80.4748 173.687 80.9681 174.526C81.5108 175.365 82.4481 176.277 83.7801 177.264L77.3421 182.888C74.5301 181.457 72.6061 179.657 71.5701 177.486C70.4848 179.015 69.0048 180.298 67.1301 181.334C65.2555 182.37 62.9368 182.888 60.1741 182.888C56.6715 182.888 53.8841 182 51.8121 180.224C49.7401 178.399 48.7041 175.833 48.7041 172.528C48.7041 169.568 49.4688 167.299 50.9981 165.72C52.5768 164.092 54.3775 162.982 56.4001 162.39C58.4228 161.798 60.6675 161.379 63.1341 161.132L66.6861 160.762C68.1168 160.614 69.1035 160.367 69.6461 160.022C70.2381 159.677 70.5588 159.109 70.6081 158.32C70.5095 156.84 70.0161 155.582 69.1281 154.546C68.2895 153.51 66.6615 152.992 64.2441 152.992C62.6655 152.992 61.2841 153.288 60.1001 153.88C58.9161 154.472 57.7075 155.434 56.4741 156.766L49.8881 152.178C51.3188 150.303 53.1195 148.873 55.2901 147.886C57.4608 146.85 60.4455 146.332 64.2441 146.332C74.9001 146.332 80.2281 150.649 80.2281 159.282V171.27ZM62.6161 176.006C65.1815 176.006 67.1548 175.389 68.5361 174.156C69.9175 172.873 70.6081 171.319 70.6081 169.494V166.386C69.8188 166.682 68.3141 166.953 66.0941 167.2L63.8741 167.422C62.1968 167.57 60.7908 167.965 59.6561 168.606C58.5215 169.198 57.9541 170.333 57.9541 172.01C57.9541 173.293 58.3735 174.279 59.2121 174.97C60.0508 175.661 61.1855 176.006 62.6161 176.006ZM110.086 182.888C105.449 182.888 101.872 181.457 99.356 178.596V182H89.736V138.118C89.736 136.786 89.4647 135.701 88.922 134.862C88.4287 134.023 87.516 133.111 86.184 132.124L92.622 126.5C95.138 127.783 96.8893 129.263 97.876 130.94C98.8627 132.568 99.356 134.862 99.356 137.822V150.846C101.921 147.837 105.498 146.332 110.086 146.332C113.342 146.332 116.105 147.121 118.374 148.7C120.693 150.229 122.419 152.301 123.554 154.916C124.689 157.481 125.256 160.318 125.256 163.426V165.794C125.256 168.902 124.689 171.763 123.554 174.378C122.419 176.943 120.693 179.015 118.374 180.594C116.105 182.123 113.342 182.888 110.086 182.888ZM107.274 175.488C109.987 175.488 112.059 174.551 113.49 172.676C114.921 170.801 115.636 168.507 115.636 165.794V163.426C115.636 160.713 114.921 158.419 113.49 156.544C112.059 154.669 109.987 153.732 107.274 153.732C103.13 153.732 100.491 155.755 99.356 159.8V169.42C100.491 173.465 103.13 175.488 107.274 175.488ZM139.613 182.888C137.097 181.605 135.345 180.15 134.359 178.522C133.372 176.845 132.879 174.526 132.879 171.566V138.118C132.879 136.786 132.607 135.701 132.065 134.862C131.571 134.023 130.659 133.111 129.327 132.124L135.765 126.5C138.281 127.783 140.032 129.263 141.019 130.94C142.005 132.568 142.499 134.862 142.499 137.822V171.27C142.499 172.602 142.745 173.687 143.239 174.526C143.781 175.365 144.719 176.277 146.051 177.264L139.613 182.888ZM167.242 182.888C162.111 182.888 158.164 181.704 155.402 179.336C152.639 176.968 151.258 173.589 151.258 169.198V160.022C151.258 155.631 152.639 152.252 155.402 149.884C158.164 147.516 162.111 146.332 167.242 146.332C172.372 146.332 176.319 147.516 179.082 149.884C181.844 152.252 183.226 155.631 183.226 160.022V169.198C183.226 173.589 181.844 176.968 179.082 179.336C176.319 181.704 172.372 182.888 167.242 182.888ZM167.242 175.488C169.264 175.488 170.818 174.945 171.904 173.86C173.038 172.775 173.606 171.221 173.606 169.198V160.022C173.606 157.999 173.038 156.445 171.904 155.36C170.818 154.275 169.264 153.732 167.242 153.732C165.219 153.732 163.64 154.275 162.506 155.36C161.42 156.445 160.878 157.999 160.878 160.022V169.198C160.878 171.221 161.42 172.775 162.506 173.86C163.64 174.945 165.219 175.488 167.242 175.488Z" | ||||
|           fill="currentColor" | ||||
|         /> | ||||
|         <defs> | ||||
|           <clipPath id="clip0_102_3"> | ||||
|             <rect | ||||
|               width="122" | ||||
|               height="148" | ||||
|               fill="currentColor" | ||||
|               transform="translate(93 102.933) rotate(-57.5343)" | ||||
|             /> | ||||
|           </clipPath> | ||||
|         </defs> | ||||
|       </svg> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Hero; | ||||
							
								
								
									
										5
									
								
								src/components/setions/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/components/setions/index.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
| import Hero from "./hero"; | ||||
| import Projects from "./projects"; | ||||
| import CV from "./cv"; | ||||
| 
 | ||||
| export { Hero, Projects, CV }; | ||||
							
								
								
									
										60
									
								
								src/components/setions/projects.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								src/components/setions/projects.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| import { Project, projects } from "@/constants"; | ||||
| import { ArrowRight } from "lucide-react"; | ||||
| import Image from "next/image"; | ||||
| import Link from "next/link"; | ||||
| import React from "react"; | ||||
| import MeCard from "../me-card"; | ||||
| import Heading from "../heading"; | ||||
| 
 | ||||
| const ProjectCard = (p: Project) => ( | ||||
|   <Link | ||||
|     href={p.link} | ||||
|     className="flex gap-12 items-center w-full group" | ||||
|     target="_blank" | ||||
|   > | ||||
|     {/* <div className="font-serif text-muted-foreground w-20">{`[ ${p.year} ]`}</div> */} | ||||
|     <div className="flex items-center gap-4 cursor-pointer hover:bg-muted w-full rounded-xl relative"> | ||||
|       <div className="h-40 w-32 relative rounded-xl overflow-hidden"> | ||||
|         <Image | ||||
|           src={p.image} | ||||
|           alt="project-image" | ||||
|           fill | ||||
|           className="object-cover" | ||||
|         /> | ||||
|       </div> | ||||
|       <div className="space-y-1"> | ||||
|         <span className="text-xs text-muted-foreground ">{`[ ${p.year} ]`}</span> | ||||
|         <h3 className="text-3xl font-black">{p.name}</h3> | ||||
|         <p className="text-muted-foreground text-lg">{p.description}</p> | ||||
|       </div> | ||||
| 
 | ||||
|       <ArrowRight className="size-6 text-primary absolute right-4 top-8 -rotate-45 group-hover:-translate-y-4 group-hover:translate-x-2 transition-all duration-300" /> | ||||
|     </div> | ||||
|   </Link> | ||||
| ); | ||||
| 
 | ||||
| function Projects() { | ||||
|   return ( | ||||
|     <div className="flex gap-8 container lg:px-20"> | ||||
|       <MeCard | ||||
|         className=" sticky top-20" | ||||
|         button={{ | ||||
|           label: "Contact Me", | ||||
|           link: "/contact/#", | ||||
|         }} | ||||
|       /> | ||||
|       <div id="projects" className="space-y-8  w-full"> | ||||
|         <Heading title="Projects" subTitle="Recent" /> | ||||
|         <menu className=" flex flex-col items-center gap-8 pb-20 w-full"> | ||||
|           {projects.map((p) => ( | ||||
|             <li key={p.link} className="w-full"> | ||||
|               <ProjectCard {...p} /> | ||||
|             </li> | ||||
|           ))} | ||||
|         </menu> | ||||
|       </div> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| export default Projects; | ||||
							
								
								
									
										115
									
								
								src/components/ui/breadcrumb.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								src/components/ui/breadcrumb.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,115 @@ | ||||
| import * as React from "react"; | ||||
| import { Slot } from "@radix-ui/react-slot"; | ||||
| import { ChevronRight, MoreHorizontal } from "lucide-react"; | ||||
| 
 | ||||
| import { cn } from "@/lib/utils"; | ||||
| 
 | ||||
| const Breadcrumb = React.forwardRef< | ||||
|   HTMLElement, | ||||
|   React.ComponentPropsWithoutRef<"nav"> & { | ||||
|     separator?: React.ReactNode; | ||||
|   } | ||||
| >(({ ...props }, ref) => <nav ref={ref} aria-label="breadcrumb" {...props} />); | ||||
| Breadcrumb.displayName = "Breadcrumb"; | ||||
| 
 | ||||
| const BreadcrumbList = React.forwardRef< | ||||
|   HTMLOListElement, | ||||
|   React.ComponentPropsWithoutRef<"ol"> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <ol | ||||
|     ref={ref} | ||||
|     className={cn( | ||||
|       "flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5", | ||||
|       className | ||||
|     )} | ||||
|     {...props} | ||||
|   /> | ||||
| )); | ||||
| BreadcrumbList.displayName = "BreadcrumbList"; | ||||
| 
 | ||||
| const BreadcrumbItem = React.forwardRef< | ||||
|   HTMLLIElement, | ||||
|   React.ComponentPropsWithoutRef<"li"> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <li | ||||
|     ref={ref} | ||||
|     className={cn("inline-flex items-center gap-1.5", className)} | ||||
|     {...props} | ||||
|   /> | ||||
| )); | ||||
| BreadcrumbItem.displayName = "BreadcrumbItem"; | ||||
| 
 | ||||
| const BreadcrumbLink = React.forwardRef< | ||||
|   HTMLAnchorElement, | ||||
|   React.ComponentPropsWithoutRef<"a"> & { | ||||
|     asChild?: boolean; | ||||
|   } | ||||
| >(({ asChild, className, ...props }, ref) => { | ||||
|   const Comp = asChild ? Slot : "a"; | ||||
| 
 | ||||
|   return ( | ||||
|     <Comp | ||||
|       ref={ref} | ||||
|       className={cn("transition-colors hover:text-foreground", className)} | ||||
|       {...props} | ||||
|     /> | ||||
|   ); | ||||
| }); | ||||
| BreadcrumbLink.displayName = "BreadcrumbLink"; | ||||
| 
 | ||||
| const BreadcrumbPage = React.forwardRef< | ||||
|   HTMLSpanElement, | ||||
|   React.ComponentPropsWithoutRef<"span"> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <span | ||||
|     ref={ref} | ||||
|     role="link" | ||||
|     aria-disabled="true" | ||||
|     aria-current="page" | ||||
|     className={cn("font-normal text-foreground", className)} | ||||
|     {...props} | ||||
|   /> | ||||
| )); | ||||
| BreadcrumbPage.displayName = "BreadcrumbPage"; | ||||
| 
 | ||||
| const BreadcrumbSeparator = ({ | ||||
|   children, | ||||
|   className, | ||||
|   ...props | ||||
| }: React.ComponentProps<"li">) => ( | ||||
|   <li | ||||
|     role="presentation" | ||||
|     aria-hidden="true" | ||||
|     className={cn("[&>svg]:w-3.5 [&>svg]:h-3.5", className)} | ||||
|     {...props} | ||||
|   > | ||||
|     {children ?? <ChevronRight />} | ||||
|   </li> | ||||
| ); | ||||
| BreadcrumbSeparator.displayName = "BreadcrumbSeparator"; | ||||
| 
 | ||||
| const BreadcrumbEllipsis = ({ | ||||
|   className, | ||||
|   ...props | ||||
| }: React.ComponentProps<"span">) => ( | ||||
|   <span | ||||
|     role="presentation" | ||||
|     aria-hidden="true" | ||||
|     className={cn("flex h-9 w-9 items-center justify-center", className)} | ||||
|     {...props} | ||||
|   > | ||||
|     <MoreHorizontal className="h-4 w-4" /> | ||||
|     <span className="sr-only">More</span> | ||||
|   </span> | ||||
| ); | ||||
| BreadcrumbEllipsis.displayName = "BreadcrumbElipssis"; | ||||
| 
 | ||||
| export { | ||||
|   Breadcrumb, | ||||
|   BreadcrumbList, | ||||
|   BreadcrumbItem, | ||||
|   BreadcrumbLink, | ||||
|   BreadcrumbPage, | ||||
|   BreadcrumbSeparator, | ||||
|   BreadcrumbEllipsis, | ||||
| }; | ||||
							
								
								
									
										57
									
								
								src/components/ui/button.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								src/components/ui/button.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,57 @@ | ||||
| import * as React from "react" | ||||
| import { Slot } from "@radix-ui/react-slot" | ||||
| import { cva, type VariantProps } from "class-variance-authority" | ||||
| 
 | ||||
| import { cn } from "@/lib/utils" | ||||
| 
 | ||||
| const buttonVariants = cva( | ||||
|   "inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", | ||||
|   { | ||||
|     variants: { | ||||
|       variant: { | ||||
|         default: | ||||
|           "bg-primary text-primary-foreground shadow hover:bg-primary/90", | ||||
|         destructive: | ||||
|           "bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90", | ||||
|         outline: | ||||
|           "border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground", | ||||
|         secondary: | ||||
|           "bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80", | ||||
|         ghost: "hover:bg-accent hover:text-accent-foreground", | ||||
|         link: "text-primary underline-offset-4 hover:underline", | ||||
|       }, | ||||
|       size: { | ||||
|         default: "h-9 px-4 py-2", | ||||
|         sm: "h-8 rounded-md px-3 text-xs", | ||||
|         lg: "h-10 rounded-md px-8", | ||||
|         icon: "h-9 w-9", | ||||
|       }, | ||||
|     }, | ||||
|     defaultVariants: { | ||||
|       variant: "default", | ||||
|       size: "default", | ||||
|     }, | ||||
|   } | ||||
| ) | ||||
| 
 | ||||
| export interface ButtonProps | ||||
|   extends React.ButtonHTMLAttributes<HTMLButtonElement>, | ||||
|     VariantProps<typeof buttonVariants> { | ||||
|   asChild?: boolean | ||||
| } | ||||
| 
 | ||||
| const Button = React.forwardRef<HTMLButtonElement, ButtonProps>( | ||||
|   ({ className, variant, size, asChild = false, ...props }, ref) => { | ||||
|     const Comp = asChild ? Slot : "button" | ||||
|     return ( | ||||
|       <Comp | ||||
|         className={cn(buttonVariants({ variant, size, className }))} | ||||
|         ref={ref} | ||||
|         {...props} | ||||
|       /> | ||||
|     ) | ||||
|   } | ||||
| ) | ||||
| Button.displayName = "Button" | ||||
| 
 | ||||
| export { Button, buttonVariants } | ||||
							
								
								
									
										178
									
								
								src/components/ui/form.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								src/components/ui/form.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,178 @@ | ||||
| "use client" | ||||
| 
 | ||||
| import * as React from "react" | ||||
| import * as LabelPrimitive from "@radix-ui/react-label" | ||||
| import { Slot } from "@radix-ui/react-slot" | ||||
| import { | ||||
|   Controller, | ||||
|   ControllerProps, | ||||
|   FieldPath, | ||||
|   FieldValues, | ||||
|   FormProvider, | ||||
|   useFormContext, | ||||
| } from "react-hook-form" | ||||
| 
 | ||||
| import { cn } from "@/lib/utils" | ||||
| import { Label } from "@/components/ui/label" | ||||
| 
 | ||||
| const Form = FormProvider | ||||
| 
 | ||||
| type FormFieldContextValue< | ||||
|   TFieldValues extends FieldValues = FieldValues, | ||||
|   TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues> | ||||
| > = { | ||||
|   name: TName | ||||
| } | ||||
| 
 | ||||
| const FormFieldContext = React.createContext<FormFieldContextValue>( | ||||
|   {} as FormFieldContextValue | ||||
| ) | ||||
| 
 | ||||
| const FormField = < | ||||
|   TFieldValues extends FieldValues = FieldValues, | ||||
|   TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues> | ||||
| >({ | ||||
|   ...props | ||||
| }: ControllerProps<TFieldValues, TName>) => { | ||||
|   return ( | ||||
|     <FormFieldContext.Provider value={{ name: props.name }}> | ||||
|       <Controller {...props} /> | ||||
|     </FormFieldContext.Provider> | ||||
|   ) | ||||
| } | ||||
| 
 | ||||
| const useFormField = () => { | ||||
|   const fieldContext = React.useContext(FormFieldContext) | ||||
|   const itemContext = React.useContext(FormItemContext) | ||||
|   const { getFieldState, formState } = useFormContext() | ||||
| 
 | ||||
|   const fieldState = getFieldState(fieldContext.name, formState) | ||||
| 
 | ||||
|   if (!fieldContext) { | ||||
|     throw new Error("useFormField should be used within <FormField>") | ||||
|   } | ||||
| 
 | ||||
|   const { id } = itemContext | ||||
| 
 | ||||
|   return { | ||||
|     id, | ||||
|     name: fieldContext.name, | ||||
|     formItemId: `${id}-form-item`, | ||||
|     formDescriptionId: `${id}-form-item-description`, | ||||
|     formMessageId: `${id}-form-item-message`, | ||||
|     ...fieldState, | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| type FormItemContextValue = { | ||||
|   id: string | ||||
| } | ||||
| 
 | ||||
| const FormItemContext = React.createContext<FormItemContextValue>( | ||||
|   {} as FormItemContextValue | ||||
| ) | ||||
| 
 | ||||
| const FormItem = React.forwardRef< | ||||
|   HTMLDivElement, | ||||
|   React.HTMLAttributes<HTMLDivElement> | ||||
| >(({ className, ...props }, ref) => { | ||||
|   const id = React.useId() | ||||
| 
 | ||||
|   return ( | ||||
|     <FormItemContext.Provider value={{ id }}> | ||||
|       <div ref={ref} className={cn("space-y-2", className)} {...props} /> | ||||
|     </FormItemContext.Provider> | ||||
|   ) | ||||
| }) | ||||
| FormItem.displayName = "FormItem" | ||||
| 
 | ||||
| const FormLabel = React.forwardRef< | ||||
|   React.ElementRef<typeof LabelPrimitive.Root>, | ||||
|   React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> | ||||
| >(({ className, ...props }, ref) => { | ||||
|   const { error, formItemId } = useFormField() | ||||
| 
 | ||||
|   return ( | ||||
|     <Label | ||||
|       ref={ref} | ||||
|       className={cn(error && "text-destructive", className)} | ||||
|       htmlFor={formItemId} | ||||
|       {...props} | ||||
|     /> | ||||
|   ) | ||||
| }) | ||||
| FormLabel.displayName = "FormLabel" | ||||
| 
 | ||||
| const FormControl = React.forwardRef< | ||||
|   React.ElementRef<typeof Slot>, | ||||
|   React.ComponentPropsWithoutRef<typeof Slot> | ||||
| >(({ ...props }, ref) => { | ||||
|   const { error, formItemId, formDescriptionId, formMessageId } = useFormField() | ||||
| 
 | ||||
|   return ( | ||||
|     <Slot | ||||
|       ref={ref} | ||||
|       id={formItemId} | ||||
|       aria-describedby={ | ||||
|         !error | ||||
|           ? `${formDescriptionId}` | ||||
|           : `${formDescriptionId} ${formMessageId}` | ||||
|       } | ||||
|       aria-invalid={!!error} | ||||
|       {...props} | ||||
|     /> | ||||
|   ) | ||||
| }) | ||||
| FormControl.displayName = "FormControl" | ||||
| 
 | ||||
| const FormDescription = React.forwardRef< | ||||
|   HTMLParagraphElement, | ||||
|   React.HTMLAttributes<HTMLParagraphElement> | ||||
| >(({ className, ...props }, ref) => { | ||||
|   const { formDescriptionId } = useFormField() | ||||
| 
 | ||||
|   return ( | ||||
|     <p | ||||
|       ref={ref} | ||||
|       id={formDescriptionId} | ||||
|       className={cn("text-[0.8rem] text-muted-foreground", className)} | ||||
|       {...props} | ||||
|     /> | ||||
|   ) | ||||
| }) | ||||
| FormDescription.displayName = "FormDescription" | ||||
| 
 | ||||
| const FormMessage = React.forwardRef< | ||||
|   HTMLParagraphElement, | ||||
|   React.HTMLAttributes<HTMLParagraphElement> | ||||
| >(({ className, children, ...props }, ref) => { | ||||
|   const { error, formMessageId } = useFormField() | ||||
|   const body = error ? String(error?.message) : children | ||||
| 
 | ||||
|   if (!body) { | ||||
|     return null | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <p | ||||
|       ref={ref} | ||||
|       id={formMessageId} | ||||
|       className={cn("text-[0.8rem] font-medium text-destructive", className)} | ||||
|       {...props} | ||||
|     > | ||||
|       {body} | ||||
|     </p> | ||||
|   ) | ||||
| }) | ||||
| FormMessage.displayName = "FormMessage" | ||||
| 
 | ||||
| export { | ||||
|   useFormField, | ||||
|   Form, | ||||
|   FormItem, | ||||
|   FormLabel, | ||||
|   FormControl, | ||||
|   FormDescription, | ||||
|   FormMessage, | ||||
|   FormField, | ||||
| } | ||||
							
								
								
									
										22
									
								
								src/components/ui/input.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/components/ui/input.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import * as React from "react"; | ||||
| 
 | ||||
| import { cn } from "@/lib/utils"; | ||||
| 
 | ||||
| const Input = React.forwardRef<HTMLInputElement, React.ComponentProps<"input">>( | ||||
|   ({ className, type, ...props }, ref) => { | ||||
|     return ( | ||||
|       <input | ||||
|         type={type} | ||||
|         className={cn( | ||||
|           "flex h-12 w-full rounded-md  bg-muted px-3 py-2 text-base shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm", | ||||
|           className | ||||
|         )} | ||||
|         ref={ref} | ||||
|         {...props} | ||||
|       /> | ||||
|     ); | ||||
|   } | ||||
| ); | ||||
| Input.displayName = "Input"; | ||||
| 
 | ||||
| export { Input }; | ||||
							
								
								
									
										26
									
								
								src/components/ui/label.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/components/ui/label.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| "use client" | ||||
| 
 | ||||
| import * as React from "react" | ||||
| import * as LabelPrimitive from "@radix-ui/react-label" | ||||
| import { cva, type VariantProps } from "class-variance-authority" | ||||
| 
 | ||||
| import { cn } from "@/lib/utils" | ||||
| 
 | ||||
| const labelVariants = cva( | ||||
|   "text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70" | ||||
| ) | ||||
| 
 | ||||
| const Label = React.forwardRef< | ||||
|   React.ElementRef<typeof LabelPrimitive.Root>, | ||||
|   React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> & | ||||
|     VariantProps<typeof labelVariants> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <LabelPrimitive.Root | ||||
|     ref={ref} | ||||
|     className={cn(labelVariants(), className)} | ||||
|     {...props} | ||||
|   /> | ||||
| )) | ||||
| Label.displayName = LabelPrimitive.Root.displayName | ||||
| 
 | ||||
| export { Label } | ||||
							
								
								
									
										159
									
								
								src/components/ui/select.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								src/components/ui/select.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,159 @@ | ||||
| "use client"; | ||||
| 
 | ||||
| import * as React from "react"; | ||||
| import * as SelectPrimitive from "@radix-ui/react-select"; | ||||
| import { Check, ChevronDown, ChevronUp } from "lucide-react"; | ||||
| 
 | ||||
| import { cn } from "@/lib/utils"; | ||||
| 
 | ||||
| const Select = SelectPrimitive.Root; | ||||
| 
 | ||||
| const SelectGroup = SelectPrimitive.Group; | ||||
| 
 | ||||
| const SelectValue = SelectPrimitive.Value; | ||||
| 
 | ||||
| const SelectTrigger = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.Trigger>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger> | ||||
| >(({ className, children, ...props }, ref) => ( | ||||
|   <SelectPrimitive.Trigger | ||||
|     ref={ref} | ||||
|     className={cn( | ||||
|       "flex h-12 w-full items-center justify-between whitespace-nowrap rounded-md bg-muted px-3 py-2 text-sm shadow-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1", | ||||
|       className | ||||
|     )} | ||||
|     {...props} | ||||
|   > | ||||
|     {children} | ||||
|     <SelectPrimitive.Icon asChild> | ||||
|       <ChevronDown className="h-4 w-4 opacity-50" /> | ||||
|     </SelectPrimitive.Icon> | ||||
|   </SelectPrimitive.Trigger> | ||||
| )); | ||||
| SelectTrigger.displayName = SelectPrimitive.Trigger.displayName; | ||||
| 
 | ||||
| const SelectScrollUpButton = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.ScrollUpButton>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollUpButton> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <SelectPrimitive.ScrollUpButton | ||||
|     ref={ref} | ||||
|     className={cn( | ||||
|       "flex cursor-default items-center justify-center py-1", | ||||
|       className | ||||
|     )} | ||||
|     {...props} | ||||
|   > | ||||
|     <ChevronUp className="h-4 w-4" /> | ||||
|   </SelectPrimitive.ScrollUpButton> | ||||
| )); | ||||
| SelectScrollUpButton.displayName = SelectPrimitive.ScrollUpButton.displayName; | ||||
| 
 | ||||
| const SelectScrollDownButton = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.ScrollDownButton>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollDownButton> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <SelectPrimitive.ScrollDownButton | ||||
|     ref={ref} | ||||
|     className={cn( | ||||
|       "flex cursor-default items-center justify-center py-1", | ||||
|       className | ||||
|     )} | ||||
|     {...props} | ||||
|   > | ||||
|     <ChevronDown className="h-4 w-4" /> | ||||
|   </SelectPrimitive.ScrollDownButton> | ||||
| )); | ||||
| SelectScrollDownButton.displayName = | ||||
|   SelectPrimitive.ScrollDownButton.displayName; | ||||
| 
 | ||||
| const SelectContent = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.Content>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content> | ||||
| >(({ className, children, position = "popper", ...props }, ref) => ( | ||||
|   <SelectPrimitive.Portal> | ||||
|     <SelectPrimitive.Content | ||||
|       ref={ref} | ||||
|       className={cn( | ||||
|         "relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md bg-muted text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2", | ||||
|         position === "popper" && | ||||
|           "data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1", | ||||
|         className | ||||
|       )} | ||||
|       position={position} | ||||
|       {...props} | ||||
|     > | ||||
|       <SelectScrollUpButton /> | ||||
|       <SelectPrimitive.Viewport | ||||
|         className={cn( | ||||
|           "p-1", | ||||
|           position === "popper" && | ||||
|             "h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]" | ||||
|         )} | ||||
|       > | ||||
|         {children} | ||||
|       </SelectPrimitive.Viewport> | ||||
|       <SelectScrollDownButton /> | ||||
|     </SelectPrimitive.Content> | ||||
|   </SelectPrimitive.Portal> | ||||
| )); | ||||
| SelectContent.displayName = SelectPrimitive.Content.displayName; | ||||
| 
 | ||||
| const SelectLabel = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.Label>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.Label> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <SelectPrimitive.Label | ||||
|     ref={ref} | ||||
|     className={cn("px-2 py-1.5 text-sm font-semibold", className)} | ||||
|     {...props} | ||||
|   /> | ||||
| )); | ||||
| SelectLabel.displayName = SelectPrimitive.Label.displayName; | ||||
| 
 | ||||
| const SelectItem = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.Item>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item> | ||||
| >(({ className, children, ...props }, ref) => ( | ||||
|   <SelectPrimitive.Item | ||||
|     ref={ref} | ||||
|     className={cn( | ||||
|       "relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50", | ||||
|       className | ||||
|     )} | ||||
|     {...props} | ||||
|   > | ||||
|     <span className="absolute right-2 flex h-3.5 w-3.5 items-center justify-center"> | ||||
|       <SelectPrimitive.ItemIndicator> | ||||
|         <Check className="h-4 w-4" /> | ||||
|       </SelectPrimitive.ItemIndicator> | ||||
|     </span> | ||||
|     <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText> | ||||
|   </SelectPrimitive.Item> | ||||
| )); | ||||
| SelectItem.displayName = SelectPrimitive.Item.displayName; | ||||
| 
 | ||||
| const SelectSeparator = React.forwardRef< | ||||
|   React.ElementRef<typeof SelectPrimitive.Separator>, | ||||
|   React.ComponentPropsWithoutRef<typeof SelectPrimitive.Separator> | ||||
| >(({ className, ...props }, ref) => ( | ||||
|   <SelectPrimitive.Separator | ||||
|     ref={ref} | ||||
|     className={cn("-mx-1 my-1 h-px bg-muted", className)} | ||||
|     {...props} | ||||
|   /> | ||||
| )); | ||||
| SelectSeparator.displayName = SelectPrimitive.Separator.displayName; | ||||
| 
 | ||||
| export { | ||||
|   Select, | ||||
|   SelectGroup, | ||||
|   SelectValue, | ||||
|   SelectTrigger, | ||||
|   SelectContent, | ||||
|   SelectLabel, | ||||
|   SelectItem, | ||||
|   SelectSeparator, | ||||
|   SelectScrollUpButton, | ||||
|   SelectScrollDownButton, | ||||
| }; | ||||
							
								
								
									
										22
									
								
								src/components/ui/textarea.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/components/ui/textarea.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import * as React from "react"; | ||||
| 
 | ||||
| import { cn } from "@/lib/utils"; | ||||
| 
 | ||||
| const Textarea = React.forwardRef< | ||||
|   HTMLTextAreaElement, | ||||
|   React.ComponentProps<"textarea"> | ||||
| >(({ className, ...props }, ref) => { | ||||
|   return ( | ||||
|     <textarea | ||||
|       className={cn( | ||||
|         "flex min-h-[60px] w-full rounded-md bg-muted px-3 py-2 text-base shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm", | ||||
|         className | ||||
|       )} | ||||
|       ref={ref} | ||||
|       {...props} | ||||
|     /> | ||||
|   ); | ||||
| }); | ||||
| Textarea.displayName = "Textarea"; | ||||
| 
 | ||||
| export { Textarea }; | ||||
							
								
								
									
										38
									
								
								src/constants/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/constants/index.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | ||||
| export type Project = { | ||||
|   name: string; | ||||
|   image: string; | ||||
|   description: string; | ||||
|   link: string; | ||||
|   year: string; | ||||
| }; | ||||
| 
 | ||||
| export const projects: Project[] = [ | ||||
|   { | ||||
|     name: "Vico Mods", | ||||
|     description: "Mods Wiki and Portfolio ", | ||||
|     image: "/vico.png", | ||||
|     link: "https://vico.shortman.me", | ||||
|     year: "2024", | ||||
|   }, | ||||
|   { | ||||
|     name: "TinaCMS X Shadcn/ui", | ||||
|     description: "Barebone starter for TinaCMS with Shadcn/ui", | ||||
|     image: "/vico.png", | ||||
|     link: "https://vico.shortman.me/2", | ||||
|     year: "2024", | ||||
|   }, | ||||
|   { | ||||
|     name: "Vico Mods", | ||||
|     description: "Mods Wiki and Portfolio ", | ||||
|     image: "/vico.png", | ||||
|     link: "https://vico.shortman.me/3", | ||||
|     year: "2023", | ||||
|   }, | ||||
|   { | ||||
|     name: "Vico Mods", | ||||
|     description: "Mods Wiki and Portfolio ", | ||||
|     image: "/vico.png", | ||||
|     link: "https://vico.shortman.me/4", | ||||
|     year: "2022", | ||||
|   }, | ||||
| ]; | ||||
							
								
								
									
										6
									
								
								src/lib/utils.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/lib/utils.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| import { clsx, type ClassValue } from "clsx" | ||||
| import { twMerge } from "tailwind-merge" | ||||
| 
 | ||||
| export function cn(...inputs: ClassValue[]) { | ||||
|   return twMerge(clsx(inputs)) | ||||
| } | ||||
| @ -1,6 +1,7 @@ | ||||
| import type { Config } from "tailwindcss"; | ||||
| 
 | ||||
| export default { | ||||
|   darkMode: ["class"], | ||||
|   content: [ | ||||
|     "./src/pages/**/*.{js,ts,jsx,tsx,mdx}", | ||||
|     "./src/components/**/*.{js,ts,jsx,tsx,mdx}", | ||||
| @ -8,11 +9,65 @@ export default { | ||||
|   ], | ||||
|   theme: { | ||||
|     extend: { | ||||
|       fontFamily: { display: ["Poppins"] }, | ||||
|       container: { | ||||
|         center: true, | ||||
|         screens: { | ||||
|           sm: "600px", | ||||
|           md: "728px", | ||||
|           lg: "984px", | ||||
|           xl: "1000px", | ||||
|           "2xl": "1050px", | ||||
|         }, | ||||
|       }, | ||||
|       colors: { | ||||
|         background: "var(--background)", | ||||
|         foreground: "var(--foreground)", | ||||
|         background: "hsl(var(--background))", | ||||
|         foreground: "hsl(var(--foreground))", | ||||
|         card: { | ||||
|           DEFAULT: "hsl(var(--card))", | ||||
|           foreground: "hsl(var(--card-foreground))", | ||||
|         }, | ||||
|         popover: { | ||||
|           DEFAULT: "hsl(var(--popover))", | ||||
|           foreground: "hsl(var(--popover-foreground))", | ||||
|         }, | ||||
|         primary: { | ||||
|           DEFAULT: "hsl(var(--primary))", | ||||
|           foreground: "hsl(var(--primary-foreground))", | ||||
|         }, | ||||
|         secondary: { | ||||
|           DEFAULT: "hsl(var(--secondary))", | ||||
|           foreground: "hsl(var(--secondary-foreground))", | ||||
|         }, | ||||
|         muted: { | ||||
|           DEFAULT: "hsl(var(--muted))", | ||||
|           foreground: "hsl(var(--muted-foreground))", | ||||
|         }, | ||||
|         accent: { | ||||
|           DEFAULT: "hsl(var(--accent))", | ||||
|           foreground: "hsl(var(--accent-foreground))", | ||||
|         }, | ||||
|         destructive: { | ||||
|           DEFAULT: "hsl(var(--destructive))", | ||||
|           foreground: "hsl(var(--destructive-foreground))", | ||||
|         }, | ||||
|         border: "hsl(var(--border))", | ||||
|         input: "hsl(var(--input))", | ||||
|         ring: "hsl(var(--ring))", | ||||
|         chart: { | ||||
|           "1": "hsl(var(--chart-1))", | ||||
|           "2": "hsl(var(--chart-2))", | ||||
|           "3": "hsl(var(--chart-3))", | ||||
|           "4": "hsl(var(--chart-4))", | ||||
|           "5": "hsl(var(--chart-5))", | ||||
|         }, | ||||
|       }, | ||||
|       borderRadius: { | ||||
|         lg: "var(--radius)", | ||||
|         md: "calc(var(--radius) - 2px)", | ||||
|         sm: "calc(var(--radius) - 4px)", | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|   plugins: [], | ||||
|   plugins: [require("tailwindcss-animate")], | ||||
| } satisfies Config; | ||||
|  | ||||
| @ -19,7 +19,8 @@ | ||||
|       } | ||||
|     ], | ||||
|     "paths": { | ||||
|       "@/*": ["./src/*"] | ||||
|       "@/*": ["./src/*"], | ||||
|       "@/ui/*": ["./src/components/ui/*"] | ||||
|     } | ||||
|   }, | ||||
|   "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user