- Install supertokens-auth-react, supertokens-node, supertokens-web-js - Create frontend and backend SuperTokens configuration - Add API route handler for auth endpoints - Add SuperTokensProvider wrapper in root layout - Create new auth component with SuperTokens UI - Configure Google and GitHub OAuth providers - Ready for SuperTokens core deployment Co-authored-by: Cursor <cursoragent@cursor.com>
72 lines
2.3 KiB
JSON
72 lines
2.3 KiB
JSON
{
|
|
"name": "vibn-frontend",
|
|
"version": "0.1.0",
|
|
"private": true,
|
|
"scripts": {
|
|
"dev": "next dev",
|
|
"build": "next build",
|
|
"start": "next start",
|
|
"lint": "eslint",
|
|
"test:db": "tsx scripts/test-alloydb.ts",
|
|
"migrate:postgres": "tsx scripts/migrate-from-postgres.ts",
|
|
"migrate:reassign": "tsx scripts/reassign-migrated-data.ts",
|
|
"firebase:emulators": "firebase emulators:start",
|
|
"firebase:deploy:rules": "firebase deploy --only firestore:rules,storage",
|
|
"firebase:deploy:indexes": "firebase deploy --only firestore:indexes",
|
|
"firebase:deploy:app": "npm run build && firebase deploy --only functions,hosting",
|
|
"firebase:deploy:all": "npm run build && firebase deploy",
|
|
"mcp:server": "node mcp-server.js"
|
|
},
|
|
"dependencies": {
|
|
"@google-cloud/vertexai": "^1.10.0",
|
|
"@google/genai": "^1.30.0",
|
|
"@google/generative-ai": "^0.24.1",
|
|
"@modelcontextprotocol/sdk": "^1.22.0",
|
|
"@radix-ui/react-alert-dialog": "^1.1.15",
|
|
"@radix-ui/react-dialog": "^1.1.15",
|
|
"@radix-ui/react-dropdown-menu": "^2.1.16",
|
|
"@radix-ui/react-label": "^2.1.8",
|
|
"@radix-ui/react-scroll-area": "^1.2.10",
|
|
"@radix-ui/react-select": "^2.2.6",
|
|
"@radix-ui/react-separator": "^1.1.8",
|
|
"@radix-ui/react-slot": "^1.2.4",
|
|
"@radix-ui/react-tabs": "^1.1.13",
|
|
"@types/pg": "^8.15.6",
|
|
"@types/uuid": "^10.0.0",
|
|
"@v0-sdk/react": "^0.4.0",
|
|
"class-variance-authority": "^0.7.1",
|
|
"clsx": "^2.1.1",
|
|
"dotenv": "^17.2.3",
|
|
"firebase": "^12.5.0",
|
|
"google-auth-library": "^10.5.0",
|
|
"lucide-react": "^0.553.0",
|
|
"next": "16.0.1",
|
|
"next-themes": "^0.4.6",
|
|
"pg": "^8.16.3",
|
|
"react": "^19.2.4",
|
|
"react-dom": "^19.2.4",
|
|
"sonner": "^2.0.7",
|
|
"supertokens-auth-react": "^0.51.2",
|
|
"supertokens-node": "^24.0.1",
|
|
"supertokens-web-js": "^0.16.0",
|
|
"tailwind-merge": "^3.4.0",
|
|
"tsx": "^4.20.6",
|
|
"uuid": "^13.0.0",
|
|
"v0-sdk": "^0.14.0",
|
|
"zod": "^3.23.8"
|
|
},
|
|
"devDependencies": {
|
|
"@tailwindcss/postcss": "^4",
|
|
"@types/node": "^20",
|
|
"@types/react": "^19",
|
|
"@types/react-dom": "^19",
|
|
"eslint": "^9",
|
|
"eslint-config-next": "16.0.1",
|
|
"firebase-admin": "^13.6.0",
|
|
"firebase-functions": "^7.0.0",
|
|
"tailwindcss": "^4",
|
|
"tw-animate-css": "^1.4.0",
|
|
"typescript": "^5"
|
|
}
|
|
}
|