## Social Media Management System - Add SocialMediaLink database model with platform, URL, icon, and ordering - Create complete CRUD API endpoints for admin social media management - Implement admin social media management page with Material-UI DataGrid - Add "Social Media" menu item to admin navigation - Update footer to dynamically load and display enabled social media links - Support multiple platforms: Facebook, Twitter, Instagram, YouTube, LinkedIn, GitHub, TikTok - Include proper icon mapping and fallback handling ## Admin Pages Improvements - Replace broken TinyMCE editor with working WYSIWYG rich text editor - Create SimpleRichEditor component with toolbar for formatting - Fix admin authentication to use cookies instead of localStorage tokens - Update all admin API calls to use credentials: 'include' - Increase content editor height to 800px for better editing experience - Add Lexical editor component as alternative (not currently used) ## Footer Pages System - Create 8 comprehensive footer pages: About, Blog, Support, API Docs, Terms, Privacy, Cookies, GDPR - Implement dynamic footer link management with smart categorization - Separate Quick Links and Legal sections with automatic filtering - Remove duplicate hardcoded links and use database-driven system - All footer pages are fully written with professional content ## Database & Dependencies - Add uuid package for ID generation - Update Prisma schema with new SocialMediaLink model and relations - Seed default social media links for Facebook, Twitter, Instagram, YouTube - Add Lexical rich text editor packages (@lexical/react, etc.) ## Technical Improvements - Fix async params compatibility for Next.js 15 - Update MUI DataGrid deprecated props - Improve admin layout navigation structure - Add proper TypeScript interfaces for all new components - Implement proper error handling and user feedback 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
96 lines
2.9 KiB
JSON
96 lines
2.9 KiB
JSON
{
|
|
"name": "biblical-guide",
|
|
"version": "1.0.0",
|
|
"main": "index.js",
|
|
"scripts": {
|
|
"dev": "next dev -p 3010",
|
|
"build": "NODE_OPTIONS='--max-old-space-size=4096' next build",
|
|
"build:fast": "NODE_OPTIONS='--max-old-space-size=2048' NEXT_PRIVATE_SKIP_SIZE_LIMIT=1 next build",
|
|
"build:analyze": "ANALYZE=true npm run build",
|
|
"build:prod": "NODE_OPTIONS='--max-old-space-size=8192' NODE_ENV=production next build",
|
|
"start": "next start -p 3010",
|
|
"lint": "next lint",
|
|
"import-bible": "tsx scripts/import-bible.ts",
|
|
"db:migrate": "npx prisma migrate deploy",
|
|
"db:generate": "npx prisma generate",
|
|
"db:studio": "npx prisma studio",
|
|
"db:seed": "npm run import-bible",
|
|
"websocket": "tsx lib/websocket/server.ts"
|
|
},
|
|
"keywords": [],
|
|
"author": "",
|
|
"license": "ISC",
|
|
"description": "",
|
|
"dependencies": {
|
|
"@emotion/react": "^11.14.0",
|
|
"@emotion/styled": "^11.14.1",
|
|
"@fontsource/roboto": "^5.2.8",
|
|
"@formatjs/intl-localematcher": "^0.6.1",
|
|
"@lexical/html": "^0.35.0",
|
|
"@lexical/link": "^0.35.0",
|
|
"@lexical/list": "^0.35.0",
|
|
"@lexical/plain-text": "^0.35.0",
|
|
"@lexical/react": "^0.35.0",
|
|
"@lexical/rich-text": "^0.35.0",
|
|
"@lexical/utils": "^0.35.0",
|
|
"@mui/icons-material": "^7.3.2",
|
|
"@mui/lab": "^7.0.0-beta.17",
|
|
"@mui/material": "^7.3.2",
|
|
"@mui/material-nextjs": "^7.3.2",
|
|
"@mui/system": "^7.3.2",
|
|
"@mui/x-charts": "^8.11.3",
|
|
"@mui/x-data-grid": "^8.11.3",
|
|
"@mui/x-date-pickers": "^8.11.3",
|
|
"@next/font": "^14.2.15",
|
|
"@prisma/client": "^6.16.2",
|
|
"@radix-ui/react-dialog": "^1.1.15",
|
|
"@radix-ui/react-dropdown-menu": "^2.1.16",
|
|
"@radix-ui/react-slot": "^1.2.3",
|
|
"@radix-ui/react-tabs": "^1.1.13",
|
|
"@radix-ui/react-toast": "^1.2.15",
|
|
"@tailwindcss/postcss": "^4.1.13",
|
|
"@tinymce/tinymce-react": "^6.3.0",
|
|
"@types/node": "^24.5.2",
|
|
"@types/pdf-parse": "^1.1.5",
|
|
"@types/pg": "^8.15.5",
|
|
"@types/react": "^19.1.13",
|
|
"@types/react-dom": "^19.1.9",
|
|
"autoprefixer": "^10.4.21",
|
|
"bcryptjs": "^3.0.2",
|
|
"class-variance-authority": "^0.7.1",
|
|
"clsx": "^2.1.1",
|
|
"jsonwebtoken": "^9.0.2",
|
|
"lexical": "^0.35.0",
|
|
"lucide-react": "^0.544.0",
|
|
"negotiator": "^1.0.0",
|
|
"next": "^15.5.3",
|
|
"next-intl": "^4.3.9",
|
|
"openai": "^5.22.0",
|
|
"pdf-parse": "^1.1.1",
|
|
"pg": "^8.16.3",
|
|
"pgvector": "^0.2.1",
|
|
"postcss": "^8.5.6",
|
|
"prisma": "^6.16.2",
|
|
"react": "^19.1.1",
|
|
"react-dom": "^19.1.1",
|
|
"react-markdown": "^10.1.0",
|
|
"recharts": "^3.2.1",
|
|
"remark-gfm": "^4.0.1",
|
|
"socket.io": "^4.8.1",
|
|
"socket.io-client": "^4.8.1",
|
|
"tailwind-merge": "^3.3.1",
|
|
"tailwindcss": "^4.1.13",
|
|
"tinymce": "^8.1.2",
|
|
"typescript": "^5.9.2",
|
|
"uuid": "^13.0.0",
|
|
"zod": "^3.25.76",
|
|
"zustand": "^5.0.8"
|
|
},
|
|
"devDependencies": {
|
|
"@types/bcryptjs": "^2.4.6",
|
|
"@types/jsonwebtoken": "^9.0.10",
|
|
"ignore-loader": "^0.1.2",
|
|
"tsx": "^4.20.5"
|
|
}
|
|
}
|